Sql语句使用规范

规范内容以及注意事项:

1、查询时候使用top 10 /top 100 和where 字句控制每次执行SQL 返回的结果集合,在满足业务需求的同时返回最小的结果。

2、使用数据投影的方式,选择前端程序需要的数据列,不允许使用select * from dbo.TableA的方式访问数据库中的列。

如:select userid , username , sex from dbo.TableA

3、尽量使用存储过程访问数据库中的数据。减少直接使用SQL 脚本访问数据库资源。

4、所有的SQL 语句都不允许使用系统表和系统字段,作为判断业务逻辑或者生成临时数据的依据。

如:select name from sys.sysobjects where xtype = ‘U’ 来查询所有的用户表。

5、编写长脚本需要注意缩进和换行,提高SQL脚本的阅读性。

如:

  1. --查询Orders
  2. Select top 10
  3. OrderID,
  4. UserID,
  5. ProductID
  6. From dbo.Orders
  7. Where
  8. --插入Orders
  9. Insert into dbo.Orders
  10. (OrderID,UserID,ProductID)
  11. Values
  12. (1,2,3)

6、插入数据的语句需要把插入字段写全。

如上:

  1. 插入orders示例,不允许写成:insert into dbo.orders select 1,2,3

7、SQL 语句调用对象的时候需要加上对象的所有者,如果是默认的所有者,需要加上dbo。

如:

  1. select userid,username from dbo.TableA 不要写成 select userid,username from TableA

8、如果需求没有强制要求返回的查询结果需要排序,SQL脚本后面不要加上Order By子句。

9、SQL语句如果设计到多表连接查询的时候,需要用表的别名,而不要使用“表名.列名”的方式。

  1. 如:select a.userid,a.username,b.sex
  2. From dbo.TableA a
  3. Join dbo.TableB b on a.userid = b.userid
  4. Where …….
  5. 错误写法:select TableA.userid,TableA.username,TableB.sex
  6. From dbo.TableA
  7. Join dbo.TableB on tableA.userid = TableB.userid
  8. Where …….

10、在大量数据插入的情况下,把需要插入的数据整合起来一起插入数据库,会节省很多资源。

如:常规写法

  1. Insert into dbo.TableA(id,name)
  2. Select 1,’aa
  3. Insert into dbo.TableA(id,name)
  4. Select 2,’bb

建议写法:

  1. Insert into dbo.TableA(id,name)
  2. Select 1,’aa
  3. Union all
  4. Select 2,’bb

建议写法2:

  1. Insert into dbo.tableA(id,name)
  2. Values(1,’aa’),(2,’bbb’)

如:常规写法:

  1. Update a
  2. Set a.userno = a.userno+1
  3. From dbo.TableA a
  4. Where a.username = ‘张三’
  5. Go
  6. Update a
  7. Set a.userno = a.userno +1
  8. From dbo.TableA a
  9. Where a.username = ‘李四’

建议写法

  1. Update a
  2. Set a.userno = a.userno+1
  3. From dbo.TableA a
  4. Where a.username in (‘张三’,’李四’)

11、 多表查询时候需要严格限制字段的别名,以防止SQL解析出现逻辑错误。

如:

  1. select
  2. OrderID,
  3. UserID
  4. from dbo.Orders
  5. where UserID in
  6. (
  7. select
  8. OrderID
  9. from dbo.UserInfo
  10. )
  11. 如果作为子查询UserInfo中没有OrderIDSQL会到父查询中寻找OrderID字段,导致逻辑错误

12、引用的对象名或字段名,严格按照其原始大小写调用

如:查询Orders表

不能写成select orderid,…. From dbo.orders …

要写成select OrderID,…. From dbo.Orders …

防止数据库编码规则更改,导致无法找到对象。

sql server 语句使用规范的更多相关文章

  1. Oracle、Mysql、Sql Server语句的区别

    1.空值的处理——判断是否为空,为空时取一个值,不为空时取另一个值 1).Sql Server 中 ISNULL(check_expression,replacement_value) 解释:如果ch ...

  2. SQL Server 语句整理

    1. 创建数据库 create database dbName 2. 删除数据库 drop database dbName 3. 备份sql server --- 创建 备份数据的 device US ...

  3. 基本的SQL Server 语句,包含 增、删、改、查 程序员必会

    这是我以前学习时, 整理的一套基础SQL Server增.删.改.查 等语句 ,初学者可以从上往下学完. 也方便自己忘记时翻看! create database SQLschool go --批 go ...

  4. sql server语句

    一.基础1.说明:创建数据库CREATE DATABASE 数据库名2.说明:删除数据库drop database 数据库名3.说明:备份sql server--- 创建 备份数据的 deviceUS ...

  5. Sql Server语句大全

    T-SQL语句大全 --跳转到SQL myDemo USE [SQL myDemo] go --声明变量id declare @id int --为变量赋值:直接赋值 --将cid为3的cname值赋 ...

  6. 常用SQL Server 语句

       常用SQL语句大全 1.//创建数据库 CREATE DATABASE DBName 2.//删除数据库 DROP DATABASE DBName 3.//备份SQL SERVER --- 创建 ...

  7. SQL SERVER 语句大全

    ·SQL的简单查询实例教程关键词:SQL语句大全 中文网 整理编辑,经典SQL语句大全(SQL语句大总结),欢迎网友投稿 下列语句部分是Mssql语句,不可以在access中使用.SQL分类:DDL— ...

  8. 经典实用SQL Server语句大全总结(一)

    简要介绍基础语句:1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql server--- 创 ...

  9. sql server 语句书写注意事项

    1  Between在某些时候比IN 2 在必要是对全局或者局部临时表创建索引,有时能够提高速度,但不是一定会这样,因为索引也耗费大量的资源.他的创建同是实际表一样 3 尽量少用视图,它的效率低.对视 ...

随机推荐

  1. JQUERY 测验

    1.下面哪种说法是正确的? 您的回答:jQuery 是 JSON 库 正确答案:jQuery 是 JavaScript 库 2.jQuery 使用 CSS 选择器来选取元素? 您的回答:错误 正确答案 ...

  2. 教你一招:Win10系统如何正确卸载edge浏览器?

    Edge浏览器作为Win10系统默认浏览器,尽管我们将其他浏览器设置为默认程序,但是有时候还是会自动弹出,非常的不爽,但是在控制面板中却又找不到卸载“Edge”浏览器的选项.下面小编就教大家卸载“Ed ...

  3. 解决:error: Cannot fetch repo (TypeError: expected string or buffer)

    同步源码,问题重现: Fetching project platform/external/libopus Fetching project repo error: Cannot fetch repo ...

  4. linux之sed用法

    参考 http://www.cnblogs.com/dong008259/archive/2011/12/07/2279897.html sed是一个很好的文件处理工具,本身是一个管道命令,主要是以行 ...

  5. Nginx简易配置文件(三)(文件缓存)

    server { listen 80; listen 443 ssl; server_name user.17.net userapi.17.net; access_log logs/user/acc ...

  6. 查找树ADT——二叉搜索树

    在以下讨论中,虽然任意复杂的关键字都是允许的,但为了简单起见,假设它们都是整数,并且所有的关键字是互异的. 总概   使二叉树成为二叉查找树的性质是,对于树中的每个节点X,它的左子树中所有关键字值小于 ...

  7. mysql5.7导入csv文件

    环境: Windows10企业版X64 mysql5.7免安装版(从5.6版本开始,官方不再提供64位的msi版本) 运行mysqld.exe启动mysql进程. 用root登录mysql: mysq ...

  8. spring aop的使用

    使用上次整合的s2sh工程,加入aop的功能.aop(面向切面编程)是一种对oop的完善,比如在进行数据库操作的时候执行方法前或者后加入一条日志记录,使用一个额外的类去做日志操作,让dao类专注地做它 ...

  9. CentOS Linux解决Device eth0 does not seem to be present

    在VMware里克隆出来的Centos Linux.. ifconfig...没有看到eth0..然后重启网卡又报下面错误. 故障现象: 解决办法: 首先,打开/etc/udev/rules.d/70 ...

  10. Aspose.Cells 导出 excel

    Aspose.Cells.Workbook book = new Aspose.Cells.Workbook(); Aspose.Cells.Worksheet sheet = book.Worksh ...