ImageVerifierCode 换一换
格式:DOCX , 页数:6 ,大小:19.95KB ,
文档编号:5351309      下载积分:9.98 文币
快捷下载
登录下载
邮箱/手机:
温馨提示:
系统将以此处填写的邮箱或者手机号生成账号和密码,方便再次下载。 如填写123,账号和密码都是123。
支付方式: 支付宝    微信支付   
验证码:   换一换

优惠套餐
 

温馨提示:若手机下载失败,请复制以下地址【https://www.163wenku.com/d-5351309.html】到电脑浏览器->登陆(账号密码均为手机号或邮箱;不要扫码登陆)->重新下载(不再收费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录  
下载须知

1: 试题类文档的标题没说有答案,则无答案;主观题也可能无答案。PPT的音视频可能无法播放。 请谨慎下单,一旦售出,概不退换。
2: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
3: 本文为用户(tanweifu)主动上传,所有收益归该用户。163文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

1,本文(标准sql语句编写格式规范经典实用sql写法.docx)为本站会员(tanweifu)主动上传,163文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。
2,用户下载本文档,所消耗的文币(积分)将全额增加到上传者的账号。
3, 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(发送邮件至3464097650@qq.com或直接QQ联系客服),我们立即给予删除!

标准sql语句编写格式规范经典实用sql写法.docx

1、项目中的那些SQL语句规范,你做到了几条?公司有SQL语句规范的参考文档,这里特别做个笔记。书写风格1. 语句关键字应全部使用小写。2. 引用字符时应使用单引号。如:update testable set idcol=abcd。3. 连接符或运算符or、in、and、=, +,- 等前后宜加上一个空格。否则容易导致以下类似问题。例如:在语句select ab from table中,a,b均为变量,拼写该语句时,如果a = 6,b = -3,则语句变为select 6-3 from table。-被视为SQL的注释,结果语句报错。4. 不得使用“select * from ”语法,必须标明字段

2、名。即select col1, col2, from tablea where 5. 严禁使用“insert into table_name values (?,?,)”语法,统一使用“insert into table_name (col1,col2,) values (?,?,.)”。6. SQL语句包含多表连接时,必须加上表的别名,对每个字段的使用都要带上表别名。即selecta.col1,a.col2,b.col3fromtablea a, tableb bwherea.col4=b.col57. 应避免显式或隐含的类型转换。例如在where子句中numeric型和int型的列的比较。

3、8. 在子查询中前后必须加上括号。selectcol1,col2fromtableawherecol3in(selectcol4fromtablebwherecol40)9. 执行SQL时一次应只执行一条,如果多条语句则应分开执行,但必须保持在一个事务中。不得一次执行通过分号等分开的多条语句,这样处理不清晰。10. 如果能采用or代替,则不宜使用in 语句。in语句中的元素不得超过500个,如果超过,则应拆分为多条SQL语句。严禁使用xx in(,.) or xx in(,)。11. or连接条件不得超过 500,超过时应拆分为多条语句。性能优化1. 查询时应尽量减少多余数据的读取,通过使用w

4、here子句来减少返回的记录数。2. 如果在语句中有not in(in)操作,应尽量用not exists(exists)来代替。特别对大数据量的两者检索速度有很明显的区别。3. 不宜使用外连接。外连接效率低。4. 一条SQL语句中不宜使用3层以上的嵌套查询。如果超过,则应在Java等应用服务器程序中处理。5. 一条SQL语句中不得从4个及以上表中同时取数。仅作关联或过滤条件而不涉及取数的表不参与表个数计算;如果必须关联4个或4个以上表,应在Java等应用服务器程序中处理。6. 应尽量避免使用order by和group by排序操作,如必须使用排序操作,尽量建立在有索引的列上。因为大量的排序

5、操作影响系统性能。7. 对索引列的比较,应尽量避免使用not 或 !=,可拆分为几个条件。因为“not”和“!=”不会使用索引。如col1 是索引列,条件col1 !=0 可以拆分为col1 0 or col2 1000)应该用如下语句代替:selectnamefromcustomerinnerjoinorderoncustomer.customerId = order.customerIdwhereorder.money 100或selectnamefromcustomerwhereexists(select1fromorderwheremoney 1000andcustomer.custo

6、merId = order.customerId)(这里需要注意:使用exists的效率依赖于匹配度,inner join效率比较稳定)11. 多表关联查询时,写法可遵循以下原则,这样做有利于建立索引,提高查询效率。格式如下:selectsum(t1.je)fromtable1 t1, table2 t2, table3 t3where(t1的等值条件and(t1的非等值条件)and(t2与t1的关联条件)and(t2的等值条件)and(t2的非等值条件)and(t3与t2的关联条件)and(t3的等值条件)and(t3的非等值条件)跨数据库支持1. 对于跨数据库Java应用程序的VO映射数据

7、库的数据格式建议:1) 整型字段:字段设置保存为Integer或者Long2) 数字型字段:若需要使用小数2位以上的精确计算,读取、插入、更新使用BigDecimal类型3) 字符型字段:读取为String,并保存为String,插入或者更新为String4) 时间字段:读取为String,插入或者更新时的时间格式使用中间件统一处理。2. 字符串连接应使用“|”符号,而不应使用“+”。“+”是SQL Server语法,Oracle和DB2支持“|”,Hibernate转化为SQL Server时,会自动将“|”转为“+”。3. 通配符不能使用a-c%这种形式。应写成如:selectcol1,c

8、ol2fromtable_namewherecol1likea%ORcol1likeb%ORcol1likec%4. 截取字符串长度函数应使用substr,起始位置为1表示从头开始。因为db2中substr起点为1,0会报错;在SqlServer数据库中使用的是substring需要进行转换。5. 不得通过select percent n和select top n限制查询结果集的记录数。6. join 与on 必须严格匹配,严禁出现没有on的join。7. joinon 后面不宜使用or,如果使用则需将or的范围用( )括起来。8. 不得使用select into 的格式。Select into是SQL Server特有语法,因为Oracle和DB2不支持。9. 应将Null值与空字符串(长度为零的字符串)视为不同。虽然Oracle视Null与空字符串为相同,但DB2和SQL Server却视为不同。

侵权处理QQ:3464097650--上传资料QQ:3464097650

【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。


163文库-Www.163Wenku.Com |网站地图|