SQL Server 查询优化 建议

本文分享了SQL查询优化的关键技巧,包括数据类型、计数操作、连续字段查询、函数使用、LIKE子句优化及索引选择原则。重点讨论了何时使用聚集索引或非聚集索引,并提供了SQL查询性能分析方法。

刚刚学习到的技巧。

数据类型datetime 一般情况下使用date就可以了

如果要计数 不要使用count(*) , 使用 count(1)

select .. in () 如果是在数据库中连续的字段,可以使用 between 代替

where 条件中尽量不要使用函数, 可以把函数迁移到程序中,还可以把该函数中比较简单的逻辑抽取出来。

like '%....%'  中前面一个 '%'不要能去掉就去掉。

何时使用聚集索引或非聚集索引?


动作描述

使用聚集索引

使用非聚集索引

列经常被分组排序

返回某范围内的数据

不应

一个或极少不同值

不应

不应

小数目的不同值

不应

大数目的不同值

不应

频繁更新的列

不应

外键列

主键列

频繁修改索引列

不应


聚类索引只需要找到要检索的所有数据中的开头和结尾数据即可;而不像非聚集索引,必须先查到目录中查到每一项数据对应的页码,然后再根据页码查到 具体内容。

所以要不要使用ID 列作为聚集索引。聚集非聚集索引使用上的选择

何时使用聚集索引?

1.检索一定范围的数据

2.读取预先排序的数据

何时不适用聚集索引?

1.频繁更新的列

2.‘宽’的关键字

3.太多并行的顺序插入

在各个select语句前加:declare @d datetime set @d=getdate()  

并在select语句后加: select [语句执行花费时间(毫秒)]=datediff(ms,@d,getdate())  


when create index  

可以将非键列包含在include() 中

关注列的唯一性,列宽度, 列数据类型。特别是列顺序,这个很重要。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值