SQL Server 小技巧【2】

本文分享了SQL查询优化的实用技巧,包括避免使用通配符查询所有字段,优化COUNT(*)的使用,正确处理数字和字符串比较,避免对索引字段进行运算和格式转换,以及如何改进多字段连接操作。
--1.不要使用×来查询所有字段
SELECT * FROM  DBO.tb1
--改为
SELECT FName,PWD,CreateDate FROM DBO.tb1 (NOLOCK)

--2.查询数据行数
SELECT COUNT(*) FROM tb1
--改为

SELECT * FROM sysindexes WHERE id =OBJECT_ID('dbo.tb1') AND indid <2


--3.数字不要加引号,不然会全盘索引 SELECT * FROM DBO.tb1 (NOLOCK) WHERE Pwd='111111' --改为 SELECT * FROM DBO.tb1 (NOLOCK) WHERE Pwd=111111

 

 

不要对索引字段进行运算

例如:

SELECT ID FROM T WHERE NUM/2=100

 

应改为:

SELECT ID FROM T WHERE NUM=100*2

SELECT ID FROM T WHERE NUM/2=NUM1

 

如果NUM有索引应改为:

SELECT ID FROM T WHERE NUM=NUM1*2

 

如果NUM1有索引则不应该改。

 

不要对索引字段进行格式转换

日期字段的例子:

WHERE CONVERT(VARCHAR(10),日期字段,120)='2014-08-15'

 

应该改为

WHERE 日期字段>='2008-08-15'  AND 日期字段<'2014-08-16'

 

不要对索引字段使用函数

日期查询的例子:

WHERE LEFT(NAME, 3)='ABC' 或者 WHERE SUBSTRING(NAME,1, 3)='ABC' 

应改为:

WHERE NAME LIKE 'ABC%'

 

日期查询的例子:

WHERE DATEDIFF(DAY, 日期,'2010-11-30')=0

 应改为:

WHERE 日期>='2010-11-30' AND 日期<'2010-12-1'

 

 

WHERE DATEDIFF(DAY, 日期,'2010-11-30')>0

 应改为:

WHERE 日期<'2010-11-30'

 

 

 

WHERE DATEDIFF(DAY, 日期,'2010-11-30')>=0

应改为:

WHERE 日期<'2010-12-01'

 

 

 

WHERE DATEDIFF(DAY, 日期,'2010-11-30')<0

应改为:

WHERE 日期>='2010-12-01'

 

 

WHERE DATEDIFF(DAY, 日期,'2014-11-30')<=0

应改为: 

WHERE 日期>='2010-11-30'

 

不要对索引字段进行多字段连接

例如:

WHERE FAME+'.'+LNAME='H.Y'

应改为:

WHERE FNAME='H' AND LNAME='Y'

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值