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 语句使用规范的更多相关文章

  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. 【转】Java面试题全集2.2(下)

    154.如何在Web项目中配置Spring的IoC容器? 答:如果需要在Web项目中使用Spring的IoC容器,可以在Web项目配置文件web.xml中做出如下配置: <context-par ...

  2. 在eclipse中部署jsp项目

    昨天在做实验的时候发现图片的路径不对,怎么改都不对,后来想到在浏览器中输入localhost:8080是tomcat服务器的路径,没找到资源是不是就是项没有部署到tomcat中,去tomcat的web ...

  3. NGUI Tween动画Scale与Transform冲突

    NGUI中我们要同时完成Scale与Transform的效果,会发现动画并不是同我们想的那样运行的. 原因就是Tween Scale与Tween Transform的冲突调用. Tween Scale ...

  4. Python中的file和open简述

    help(file) help(open) 老规矩先看一下内置的帮助文档怎么描述file和open,毕竟官方文档是最直接最准确的描述. Help on class file in module __b ...

  5. java并发编程实战(java concurrency in practice)

    第一章   线程共享进程范围内的资源,但每个线程都有各自的程序计数器.栈以及局部变量等. 多个线程可以同时调度到多个CPU上运行.   线程的优势? 在服务应用程序中,可以提升资源利用率以及系统吞吐率 ...

  6. Let & Const

    Let & Const let 基础用法 很简单就能说明这个问题 if(false) { var a = 'heihei' } a = undefined if(true) { var a = ...

  7. ionic browser+ios头部高度显示问题

    ionic项目在使用ionic build browser或者打包ios时如果设置头部高度 方法如下 .bar-header { padding:; height:; } .scroll-conten ...

  8. welcome to learn prgram

    Tips for your suceess(成功的秘诀) 1. Practice every day(每天练习) 每天用两小时来学习.你可以使用各种零碎时间,积少成多.你可以使用搞这些时间用来巩固练习 ...

  9. Win10---------专区

    待完善中---------------------------------- -----------------------------------------The End------------- ...

  10. LoadRunner 函数之lr_xml_get_values

    简单实例如 char *xml_input = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>&q ...