SQL代码规范
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了SQL代码规范,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2384字,纯文字阅读大概需要4分钟。
内容图文
1. 建表规约
1) 表中字段名称
a) 表达是否概念的字段,必须使用is_xxx的方式命名,数据类型是bit
b) 小数类型为decimal,禁止使用float和double。
说明:float和double在存储的时候,存在精度损失的问题,很可能在值得比较时,得到不正确的结果。如果存储的数据范围超过decimal的范围,建议将数据拆成整数和小数分开存储。
c) 字段允许适当的冗余,以提高性能,但是必须考虑数据同步的情况
冗余字段应遵循:
n 不是频繁修改的字段。
n 不是varchar超长字段,更不能是text字段
2) 主键索引名为pk_字段名;唯一索引名为uk_字段名;普通索引名则为idx_字段名。
说明:pk_即primary key,uk_即unique key;idx_即index的简称。
2. SQL规约
1) 不要使用count(列名)或count(常量)来替代count(*),count(*)是SQL92 定义的 标准统计行数的语法,跟数据库无关,跟 NULL 有关。
说明:count(*)会统计值为NULL的行,而count(列名)不会统计此列为NULL值的行。
2) 使用ISNULL()来判断是否为NULL值。
注意:NULL与任何值的直接比较都为 NULL。
说明:
1)NULL<>NULL 的返回结果是NULL,而不是false。
2)NULL=NULL 的返回结果是NULL,而不是true。
3)NULL<>1 的返回结果是NULL,而不是true。
3) 在代码中写分页查询逻辑时,若count为0应直接返回,避免执行后面的分页语句。
4) 不得使用外键与级联,一切外键概念必须在应用层解决。
说明:学生表中的student_id是主键,那么成绩表中的student_id则为外键。如果更新学生表中的student_id,同时触发成绩表中的student_id更新,则为级联更新。外键与级联更新适用于单机低并发,不适合分布式、高并发集群;级联更新是强阻塞,存在数据库更新风暴的风险;外键影响数据库的插入速度。
4) 避免使用存储过程,存储过程难以调试和扩展,更没有移植性。
5) 数据订正时,删除和修改记录时,要先select,避免出现误删除,确认无误才能执行更新语句。
6) in操作能避免则避免,若实在避免不了,需要仔细评估in后边的集合元素数量,控制在1000个之内。
7) TRUNCATE TABLE比DELETE速度快,且使用的系统和事务日志资源少,但TRUNCATE无事务且不触发trigger,有可能造成事故,故不建议在开发代码中使用此语句。
说明:DELETE语句必须带条件where,删除全表也可加where 1=1。
8) 在表查询中,一律不要使用 * 作为查询的字段列表,需要哪些字段必须明确写明。
9) 不要写一个大而全的数据更新接口,不管是不是自己的目标更新字段,都进行update这是不对的。执行 SQL 时,尽量不要更新无改动的字段,一是易出错;二是效率低。
SQL代码规范
标签:有关 方式 应用 数据 比较 提高 char HERE 适合
本文系统来源:https://www.cnblogs.com/Williamls/p/11202517.html
内容总结
以上是互联网集市为您收集整理的SQL代码规范全部内容,希望文章能够帮你解决SQL代码规范所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。