sql server 语句使用规范
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脚本的阅读性。
如:
- --查询Orders
- Select top 10
- OrderID,
- UserID,
- ProductID
- From dbo.Orders
- Where …
- --插入Orders
- Insert into dbo.Orders
- (OrderID,UserID,ProductID)
- Values
- (1,2,3)
6、插入数据的语句需要把插入字段写全。
如上:
- 插入orders示例,不允许写成:insert into dbo.orders select 1,2,3
7、SQL 语句调用对象的时候需要加上对象的所有者,如果是默认的所有者,需要加上dbo。
如:
- select userid,username from dbo.TableA 不要写成 select userid,username from TableA
8、如果需求没有强制要求返回的查询结果需要排序,SQL脚本后面不要加上Order By子句。
9、SQL语句如果设计到多表连接查询的时候,需要用表的别名,而不要使用“表名.列名”的方式。
- 如:select a.userid,a.username,b.sex
- From dbo.TableA a
- Join dbo.TableB b on a.userid = b.userid
- Where …….
- 错误写法:select TableA.userid,TableA.username,TableB.sex
- From dbo.TableA
- Join dbo.TableB on tableA.userid = TableB.userid
- Where …….
10、在大量数据插入的情况下,把需要插入的数据整合起来一起插入数据库,会节省很多资源。
如:常规写法
- Insert into dbo.TableA(id,name)
- Select 1,’aa’
- Insert into dbo.TableA(id,name)
- Select 2,’bb’
建议写法:
- Insert into dbo.TableA(id,name)
- Select 1,’aa’
- Union all
- Select 2,’bb’
建议写法2:
- Insert into dbo.tableA(id,name)
- Values(1,’aa’),(2,’bbb’)
如:常规写法:
- Update a
- Set a.userno = a.userno+1
- From dbo.TableA a
- Where a.username = ‘张三’
- Go
- Update a
- Set a.userno = a.userno +1
- From dbo.TableA a
- Where a.username = ‘李四’
建议写法
- Update a
- Set a.userno = a.userno+1
- From dbo.TableA a
- Where a.username in (‘张三’,’李四’)
11、 多表查询时候需要严格限制字段的别名,以防止SQL解析出现逻辑错误。
如:
- select
- OrderID,
- UserID
- from dbo.Orders
- where UserID in
- (
- select
- OrderID
- from dbo.UserInfo
- )
- 如果作为子查询UserInfo中没有OrderID,SQL会到父查询中寻找OrderID字段,导致逻辑错误
12、引用的对象名或字段名,严格按照其原始大小写调用
如:查询Orders表
不能写成select orderid,…. From dbo.orders …
要写成select OrderID,…. From dbo.Orders …
防止数据库编码规则更改,导致无法找到对象。
sql server 语句使用规范的更多相关文章
- Oracle、Mysql、Sql Server语句的区别
1.空值的处理——判断是否为空,为空时取一个值,不为空时取另一个值 1).Sql Server 中 ISNULL(check_expression,replacement_value) 解释:如果ch ...
- SQL Server 语句整理
1. 创建数据库 create database dbName 2. 删除数据库 drop database dbName 3. 备份sql server --- 创建 备份数据的 device US ...
- 基本的SQL Server 语句,包含 增、删、改、查 程序员必会
这是我以前学习时, 整理的一套基础SQL Server增.删.改.查 等语句 ,初学者可以从上往下学完. 也方便自己忘记时翻看! create database SQLschool go --批 go ...
- sql server语句
一.基础1.说明:创建数据库CREATE DATABASE 数据库名2.说明:删除数据库drop database 数据库名3.说明:备份sql server--- 创建 备份数据的 deviceUS ...
- Sql Server语句大全
T-SQL语句大全 --跳转到SQL myDemo USE [SQL myDemo] go --声明变量id declare @id int --为变量赋值:直接赋值 --将cid为3的cname值赋 ...
- 常用SQL Server 语句
常用SQL语句大全 1.//创建数据库 CREATE DATABASE DBName 2.//删除数据库 DROP DATABASE DBName 3.//备份SQL SERVER --- 创建 ...
- SQL SERVER 语句大全
·SQL的简单查询实例教程关键词:SQL语句大全 中文网 整理编辑,经典SQL语句大全(SQL语句大总结),欢迎网友投稿 下列语句部分是Mssql语句,不可以在access中使用.SQL分类:DDL— ...
- 经典实用SQL Server语句大全总结(一)
简要介绍基础语句:1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql server--- 创 ...
- sql server 语句书写注意事项
1 Between在某些时候比IN 2 在必要是对全局或者局部临时表创建索引,有时能够提高速度,但不是一定会这样,因为索引也耗费大量的资源.他的创建同是实际表一样 3 尽量少用视图,它的效率低.对视 ...
随机推荐
- JQUERY 测验
1.下面哪种说法是正确的? 您的回答:jQuery 是 JSON 库 正确答案:jQuery 是 JavaScript 库 2.jQuery 使用 CSS 选择器来选取元素? 您的回答:错误 正确答案 ...
- 教你一招:Win10系统如何正确卸载edge浏览器?
Edge浏览器作为Win10系统默认浏览器,尽管我们将其他浏览器设置为默认程序,但是有时候还是会自动弹出,非常的不爽,但是在控制面板中却又找不到卸载“Edge”浏览器的选项.下面小编就教大家卸载“Ed ...
- 解决:error: Cannot fetch repo (TypeError: expected string or buffer)
同步源码,问题重现: Fetching project platform/external/libopus Fetching project repo error: Cannot fetch repo ...
- linux之sed用法
参考 http://www.cnblogs.com/dong008259/archive/2011/12/07/2279897.html sed是一个很好的文件处理工具,本身是一个管道命令,主要是以行 ...
- Nginx简易配置文件(三)(文件缓存)
server { listen 80; listen 443 ssl; server_name user.17.net userapi.17.net; access_log logs/user/acc ...
- 查找树ADT——二叉搜索树
在以下讨论中,虽然任意复杂的关键字都是允许的,但为了简单起见,假设它们都是整数,并且所有的关键字是互异的. 总概 使二叉树成为二叉查找树的性质是,对于树中的每个节点X,它的左子树中所有关键字值小于 ...
- mysql5.7导入csv文件
环境: Windows10企业版X64 mysql5.7免安装版(从5.6版本开始,官方不再提供64位的msi版本) 运行mysqld.exe启动mysql进程. 用root登录mysql: mysq ...
- spring aop的使用
使用上次整合的s2sh工程,加入aop的功能.aop(面向切面编程)是一种对oop的完善,比如在进行数据库操作的时候执行方法前或者后加入一条日志记录,使用一个额外的类去做日志操作,让dao类专注地做它 ...
- CentOS Linux解决Device eth0 does not seem to be present
在VMware里克隆出来的Centos Linux.. ifconfig...没有看到eth0..然后重启网卡又报下面错误. 故障现象: 解决办法: 首先,打开/etc/udev/rules.d/70 ...
- Aspose.Cells 导出 excel
Aspose.Cells.Workbook book = new Aspose.Cells.Workbook(); Aspose.Cells.Worksheet sheet = book.Worksh ...