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 尽量少用视图,它的效率低.对视 ...
随机推荐
- 响应式疑惑? CSS单位研究
各种单位要搞清楚,自己试一试,实践出真知! 2.屏幕分辨率 响应式 哦,电脑的分辨率:1440x900表示水平有1440个像素点哦! 垂直有900个像素点. 而网页在浏览器中,所以宽度是电脑的分 ...
- iOS开发小技巧--相机相册的正确打开方式
iOS相机相册的正确打开方式- UIImagePickerController 通过指定sourceType来实现打开相册还是相机 UIImagePickerControllerSourceTypeP ...
- ubuntu下升级R版本
ubuntu下升级R版本 在测试<机器学习 实用案例解析>一书的邮件分类代码时,windows系统下rstudio中无法读取特殊字符,在ubuntu下可以.在ubuntu虚拟机下安装t ...
- Introduction - SNMP Tutorial
30.1 Introduction In addition to protocols that provide network level services and application progr ...
- MySQL主从同步延迟
早上接到open-falcon报警,一台mysql从库同步延迟2w多秒,mysql版本比较老,用的5.1.37. 连接从库查找原因: show processlist一下,查看哪些线程在跑. 看到Ti ...
- (转)MySQL索引原理及慢查询优化
转自美团技术博客,原文地址:http://tech.meituan.com/mysql-index.html 建索引的一些原则: 1.最左前缀匹配原则,非常重要的原则,mysql会一直向右匹配直到遇到 ...
- OPenCL
OpenCLhttp://baike.baidu.com/link?url=7uHWCVUYB3Sau_xh3OOKP-A08_IvmT1SJixdAXKezCuCfkzeSQDiSmesGyVGk8 ...
- css 图片垂直居中总结
1.利用vertical-align:middle: 父级元素设置成display:table-cell; 同级元素设置一个span标签 设置display:inline-block:图片样式设置ve ...
- 数据库大数据处理---复制(SQLServer)
复制? 复制起初并不是用于作为高可用性功能而设计的,实际上复制的概念就像其名称一样,用于复制数据.比如将某个库中的数据“复制”到另一个库,到另一个实例中,由OLTP复制到OLAP环境中,由某数据中心复 ...
- ActiveMQ启动多个broker
具体步骤如下: 1.把activemq目录下的conf文件复制一份,叫做conf2, 命令: cp -r conf conf2 2.修改conf2目录下的activemq.xml文件 a.修改brok ...