[20141114]这些年你需要注意的SQL

*:first-child {
margin-top: 0 !important;
}

body>*:last-child {
margin-bottom: 0 !important;
}

/* BLOCKS
=============================================================================*/

p, blockquote, ul, ol, dl, table, pre {
margin: 15px 0;
}

/* HEADERS
=============================================================================*/

h1, h2, h3, h4, h5, h6 {
margin: 20px 0 10px;
padding: 0;
font-weight: bold;
-webkit-font-smoothing: antialiased;
}

h1 tt, h1 code, h2 tt, h2 code, h3 tt, h3 code, h4 tt, h4 code, h5 tt, h5 code, h6 tt, h6 code {
font-size: inherit;
}

h1 {
font-size: 28px;
color: #000;
}

h2 {
font-size: 24px;
border-bottom: 1px solid #ccc;
color: #000;
}

h3 {
font-size: 18px;
}

h4 {
font-size: 16px;
}

h5 {
font-size: 14px;
}

h6 {
color: #777;
font-size: 14px;
}

body>h2:first-child, body>h1:first-child, body>h1:first-child+h2, body>h3:first-child, body>h4:first-child, body>h5:first-child, body>h6:first-child {
margin-top: 0;
padding-top: 0;
}

a:first-child h1, a:first-child h2, a:first-child h3, a:first-child h4, a:first-child h5, a:first-child h6 {
margin-top: 0;
padding-top: 0;
}

h1+p, h2+p, h3+p, h4+p, h5+p, h6+p {
margin-top: 10px;
}

/* LINKS
=============================================================================*/

a {
color: #4183C4;
text-decoration: none;
}

a:hover {
text-decoration: underline;
}

/* LISTS
=============================================================================*/

ul, ol {
padding-left: 30px;
}

ul li > :first-child,
ol li > :first-child,
ul li ul:first-of-type,
ol li ol:first-of-type,
ul li ol:first-of-type,
ol li ul:first-of-type {
margin-top: 0px;
}

ul ul, ul ol, ol ol, ol ul {
margin-bottom: 0;
}

dl {
padding: 0;
}

dl dt {
font-size: 14px;
font-weight: bold;
font-style: italic;
padding: 0;
margin: 15px 0 5px;
}

dl dt:first-child {
padding: 0;
}

dl dt>:first-child {
margin-top: 0px;
}

dl dt>:last-child {
margin-bottom: 0px;
}

dl dd {
margin: 0 0 15px;
padding: 0 15px;
}

dl dd>:first-child {
margin-top: 0px;
}

dl dd>:last-child {
margin-bottom: 0px;
}

/* CODE
=============================================================================*/

pre, code, tt {
font-size: 12px;
font-family: Consolas, "Liberation Mono", Courier, monospace;
}

code, tt {
margin: 0 0px;
padding: 0px 0px;
white-space: nowrap;
border: 1px solid #eaeaea;
background-color: #f8f8f8;
border-radius: 3px;
}

pre>code {
margin: 0;
padding: 0;
white-space: pre;
border: none;
background: transparent;
}

pre {
background-color: #f8f8f8;
border: 1px solid #ccc;
font-size: 13px;
line-height: 19px;
overflow: auto;
padding: 6px 10px;
border-radius: 3px;
}

pre code, pre tt {
background-color: transparent;
border: none;
}

kbd {
-moz-border-bottom-colors: none;
-moz-border-left-colors: none;
-moz-border-right-colors: none;
-moz-border-top-colors: none;
background-color: #DDDDDD;
background-image: linear-gradient(#F1F1F1, #DDDDDD);
background-repeat: repeat-x;
border-color: #DDDDDD #CCCCCC #CCCCCC #DDDDDD;
border-image: none;
border-radius: 2px 2px 2px 2px;
border-style: solid;
border-width: 1px;
font-family: "Helvetica Neue",Helvetica,Arial,sans-serif;
line-height: 10px;
padding: 1px 4px;
}

/* QUOTES
=============================================================================*/

blockquote {
border-left: 4px solid #DDD;
padding: 0 15px;
color: #777;
}

blockquote>:first-child {
margin-top: 0px;
}

blockquote>:last-child {
margin-bottom: 0px;
}

/* HORIZONTAL RULES
=============================================================================*/

hr {
clear: both;
margin: 15px 0;
height: 0px;
overflow: hidden;
border: none;
background: transparent;
border-bottom: 4px solid #ddd;
padding: 0;
}

/* IMAGES
=============================================================================*/

img {
max-width: 100%
}
-->

#1、使用对象时,请显式的指定对象的架构者(默认为dbo)

分析:在SQL SERVER中,如果用户User1访问表table1,那么查询分析器必须决定是检索 User1.table1 还是 dbo.table1 。所以每次User1访问同一张表table1时,查询分析器都必须对查询计划 重编译,影响执行速度。

#2、尽量避免使用SELECT *,建议使用 SELECT

分析:采用SELECT * 语法会导致DB对列进行一个遍历,同时可能会查询多余字段数据(本着用啥查啥的原则,建议使用SELECT <Field List>),导致查询性能下降。

#3、如果一个T-SQL语句涉及到多个表,则引用的每个列必须制定该列所属的对象

分析:避免造成数据查询异常

#4、Insert语句中必须指定插入列的列表

分析:避免表列变化导致插入语句失败

#5、在非事物和特别要求完整性的上下文中,使用NOLOCK查询

分析:考虑到并发性,提高查询效率

示例:

SELECT TOP 100 COL1,COL2 FROM TABLE1 t1 WITH (NOLOCK)

#6、通过SELECT语句对变量赋值时,如果未使用聚合函数,请加上TOP 1

分析:防止结果非预期

示例:(预期结果为2,因为第二次Name2是后添加的。)

CREATE TABLE test6
(
Id int
,Name nvarchar(32)
) INSERT INTO test6 (Id, Name)
SELECT 1, N'Name1'
UNION all
SELECT 2, N'Name2' INSERT INTO test6 (Id, Name)
SELECT 3, N'Name2' --错误的写法
DECLARE @Id int
SELECT
@Id=Id
FROM test6
WHERE
Name = 'Name2' --正确的写法
DECLARE @Id int
SELECT TOP 1
@Id=Id
FROM test6
WHERE
Name = 'Name2'

#7、对于排序后取字段TOP 1的值,建议使用聚合

分析:可以用上索引,而且不需要Table Scan

示例:

--错误的写法
SELECT TOP 1 col1 FROM table1 ORDER BY col1 DESC --正确的写法
SELECT MAX(col1) FROM table1

#8、有关char和varchar,char和nchar,varchar和nvarchar的区别

分析:

  1. char是固定长度,如果数据不够,会在存储时自动补空格
  2. varchar是可变长度,会有三个字节来存储字段信息,可以设置最大长度
  3. nchar和varchar这种以N开头的表示存储unicode编码字符
  4. 在特定字符集下,如果定义数据格式为char或者是varchar,那么存储特殊字符(包括中文)会乱码
  5. 关于数据库函数LEN(),是用于返回指定字符串表达式的字符数,其中不包含尾随空格。
  6. 关于DATALENGTH函数,返回用于表示任何表达式的字节数。

示例:

DECLARE @s1 CHAR(5)
,@s2 VARCHAR(5)
,@s3 NCHAR(5)
,@s4 NVARCHAR(5) --看看这个结果是什么?
SET @s1 = 'test'
SET @s2 = 'test'
SET @s3 = 'test'
SET @s4 = 'test'
SELECT
LEN(@s1)
,LEN(@s2)
,LEN(@s3)
,Len(@s4)
SELECT
DATALENGTH(@s1)
,DATALENGTH(@s2)
,DATALENGTH(@s3)
,DATALENGTH(@s4) --如果这样呢?
SET @s1 = '我是中文'
SET @s2 = '我是中文'
SET @s3 = '我是中文'
SET @s4 = '我是中文'
SELECT
LEN(@s1)
,LEN(@s2)
,LEN(@s3)
,Len(@s4)
SELECT
DATALENGTH(@s1)
,DATALENGTH(@s2)
,DATALENGTH(@s3)
,DATALENGTH(@s4) --一般情况下,SELECT @s1,@s2,@s3,@s4不会显示乱码,是由于安装SQL SERVER的时候后默认字符集是支持unicode字符的。如果遇到不支持的字符集,就需要显示定义字段类型为带N的类型,同时在赋值的时候使用N'中文'这种形式。

#9、禁止在使用了事物的情况下,不编写防止造成未提交或者未回滚事务的情况的处理代码

分析:数据库阻塞,你懂的...罪过大大的!

#10、警惕表变量的使用

示例:

--思考下结果是什么?
IF NOT exists (SELECT 1)
BEGIN
PRINT 'enter'
DECLARE @table TABLE
(
name nvarchar(32)
)
END
SELECT name FROM @table

分析:

  1. 在表变量的使用中,会出现如JavaScript一样的定义前置,相当于不管你在哪个条件(也不关心是否能走到这个分支)中定义表变量,那么这个表变量在整个作用域中都是有效的。
  2. 临时表表现正常
  3. 表变量和一般的变量有点不一样的地方,表变量也会在tempdb中创建表。示例如下:

CREATE TABLE #TempTable (TT_Col1 INT)
DECLARE @TableVariable TABLE (TV_Col1 INT) SELECT TOP 2 *
FROM tempdb.sys.tables
ORDER BY create_date DESC

#11、判断是否存在(或者不存在)符合条件的记录使用 EXISTS 关键字。

分析:

IF (SELECT COUNT(*) FROM Table WITH (NOLOCK))>0
BEGIN
--Do something
END
--应该用:
IF EXISTS(SELECT TOP 1 1 FROM Table WITH (NOLOCK)
BEGIN
--Do something
END

#12、字符串比较时,SQL SERVER会忽略末尾的空格。

示例:

SELECT 1
WHERE 't' ='t '

#13、注意NULL的特殊性

分析:

1.NULL既不能被=匹配,也不能被<>(!=)匹配,只能用IS NULL 或者是 ISNULL()

示例:

CREATE TABLE #tb(col1 int)
INSERT INTO #tb(col1)
SELECT NULL
UNION
SELECT 1
UNION
SELECT 2 SELECT COUNT(*) FROM #tb
WHERE col1 <> 1 OR col1 = 1 --2 SELECT COUNT(*) FROM #tb --3

14、COUNT(0),COUNT(*),COUNT(column)的区别

分析:

  1. COUNT(0),COUNT(*)计数时会包含NULL值
  2. COUNT(column)计数时,如果需要该列为NULL,则会忽略计数

示例:

CREATE TABLE #tb(col1 int)
INSERT INTO #tb(col1)
SELECT NULL
UNION
SELECT 1
UNION
SELECT 2 SELECT COUNT(*) FROM #tb --3
SELECT COUNT(0) FROM #tb --3
SELECT COUNT(col1) FROM #tb --2

#15、通过合理的方法避免在 SELECT 语句中使用 DISTINCT

分析:

  1. DISTINCT 是数据查询中一个非常慢的操作,所以尽可能的避免

示例:

SELECT DISTINCT
A.au_fname
,A.au_lname
FROM dbo.authors AS A WITH (NOLOCK)
INNER JOIN dbo.titleAuthor AS T WITH (NOLOCK) --一对多的关系
ON T.au_id = A.au_id --避免DISTINCT的写法
SELECT au_fname
,au_lname
FROM dbo.authors AS A WITH (NOLOCK)
WHERE EXISTS (
SELECT TOP 1 1
FROM dbo.titleAuthor AS T WITH (NOLOCK)
WHERE T.au_id = A.au_id

这些年你需要注意的SQL的更多相关文章

  1. 最近帮客户实施的基于SQL Server AlwaysOn跨机房切换项目

    最近帮客户实施的基于SQL Server AlwaysOn跨机房切换项目 最近一个来自重庆的客户找到走起君,客户的业务是做移动互联网支付,是微信支付收单渠道合作伙伴,数据库里存储的是支付流水和交易流水 ...

  2. SQL Server 大数据搬迁之文件组备份还原实战

    一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 解决方案(Solution) 搬迁步骤(Procedure) 搬迁脚本(SQL Codes) ...

  3. Sql Server系列:分区表操作

    1. 分区表简介 分区表在逻辑上是一个表,而物理上是多个表.从用户角度来看,分区表和普通表是一样的.使用分区表的主要目的是为改善大型表以及具有多个访问模式的表的可伸缩性和可管理性. 分区表是把数据按设 ...

  4. SQL Server中的高可用性(2)----文件与文件组

        在谈到SQL Server的高可用性之前,我们首先要谈一谈单实例的高可用性.在单实例的高可用性中,不可忽略的就是文件和文件组的高可用性.SQL Server允许在某些文件损坏或离线的情况下,允 ...

  5. EntityFramework Core Raw SQL

    前言 本节我们来讲讲EF Core中的原始查询,目前在项目中对于简单的查询直接通过EF就可以解决,但是涉及到多表查询时为了一步到位就采用了原始查询的方式进行.下面我们一起来看看. EntityFram ...

  6. 从0开始搭建SQL Server AlwaysOn 第一篇(配置域控)

    从0开始搭建SQL Server AlwaysOn 第一篇(配置域控) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://www.cnb ...

  7. 从0开始搭建SQL Server AlwaysOn 第二篇(配置故障转移集群)

    从0开始搭建SQL Server AlwaysOn 第二篇(配置故障转移集群) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://www ...

  8. 从0开始搭建SQL Server AlwaysOn 第三篇(配置AlwaysOn)

    从0开始搭建SQL Server AlwaysOn 第三篇(配置AlwaysOn) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://w ...

  9. 从0开始搭建SQL Server AlwaysOn 第四篇(配置异地机房节点)

    从0开始搭建SQL Server AlwaysOn 第四篇(配置异地机房节点) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://www ...

  10. SQL Server on Linux 理由浅析

    SQL Server on Linux 理由浅析 今天的爆炸性新闻<SQL Server on Linux>基本上在各大科技媒体上刷屏了 大家看到这个新闻都觉得非常震精,而美股,今天微软开 ...

随机推荐

  1. PHP之負載均衡下的session共用

    最近忙於開發台灣運動彩券第四版的程式,所以已經很久沒有上來寫東西了,今天隨便寫點東西和大家分享. 首先說一下負載均衡,相信大家都知道負載均衡可以很好地解決網站大流量的問題,負載均衡就是把用戶的請求分發 ...

  2. Javascript中的Prototype到底是啥

    Javascript也是面向对象的语言,但它是一种基于原型Prototype的语言,而不是基于类的语言.在Javascript中,类和对象看起来没有太多的区别. 通常,这样创建一个对象: functi ...

  3. js 排列 组合 的一个简单例子

    最近工作项目需要用到js排列组合,于是就写了一个简单的demo. 前几天在网上找到一个写全排列A(n,n)的code感觉还可以,于是贴出来了, 排列的实现方式: 全排列主要用到的是递归和数组的插入 比 ...

  4. 【Android】 Android-wifi 直连 wifi direct wifi p2p

    现在,Android的支持Wi -Fi的直接点对点点对点(P2P)Android系统的供电设备和其他类型的设备,没有一个热点或互联网连接之间的连接.Android框架提供了一套Wi - Fi的P2P的 ...

  5. svg―Raphael.js Library(一)

    Raphael是一个用于在网页中绘制矢量图形的Javascript库,它使用SVG W3C推荐标准和VML作为创建图形的基础,可以通过JavaScript操作DOM来轻松创建出各种复杂的柱状图.饼图. ...

  6. 如何清除朗逸保养提示标志INSP

    自己消除insp小扳手方法 具体步骤如下1.插入钥匙,不要转动.2.按住显示屏下方右边的黑圆柱按钮 3.钥匙转到2档,通电自检,期间按住按钮不要松手4.过10秒左右,INSP消失,小扳手自己去除 不用 ...

  7. SQL Server 2012 各版本功能比较

    有关不同版本的 SQL Server 2012 所支持的功能的详细信息. 功能名称 Enterprise 商业智能 Standard Web Express with Advanced Service ...

  8. ARCGIS 10.1 发布服务问题以及注意事项汇总

    本文会逐渐丰富,并在遇到问题后进行整理进来. 一.了解ArcGIS Server以及如何利用ArcServer发布服务 官方中文帮助文档:http://resources.arcgis.com/zh- ...

  9. Winform下richtextbox截图实现

    #region 根据richtextbox创建GDI+ private void DrawGDI(RichTextBox rich,Panel panl,PictureBox p2) { rich.U ...

  10. [原]unity5 AssetBundle打包

    本文unity版本5.1.3 一.现有的打包教程: 1.http://liweizhaolili.blog.163.com/blog/static/16230744201541410275298/ 阿 ...