时间:2021-07-01 10:21:17 帮助过:29人阅读
like本身效率就比较低,应该尽量避免查询条件使用like;
原因:
解决办法:
原因:
解决方法:
原因:
解决方法:
原因:
select id from t where id in(1,2,3) => select id from t where id between 1 and 3 |
原因:
解决方法:
select id from t where id/2 = 10 => select id from t where id = 2 * 10 |
原因:
解决方法:
select id from t where substring(id,1,2) = ‘abcd’ => select id from t where id like ‘abcd%’ |
select id from t where datediff(day,createdate,’2017-09-08′) = 0 => select id from t where createdate >= ‘2016-11-30‘ and createdate < ‘2016-12-1‘ |
原因:
1) 尽可能的使用 varchar/nvarchar 代替 char/nchar ,因为首先变长字段存储空间小,可以节省存储空间,其次对于查询来说,在一个相对较小的字段内搜索效率显然要高些。
2) 任何地方都不要使用 select * from t ,用具体的字段列表代替“*”,不要返回用不到的任何字段。
3) 尽量使用表变量来代替临时表。如果表变量包含大量数据,请注意索引非常有限(只有主键索引)
4) 避免频繁创建和删除临时表,以减少系统表资源的消耗。临时表并不是不可使用,适当地使用它们可以使某些例程更有效,例如,当需要重复引用大型表或常用表中的某个数据集时。但是,对于一次性事件, 最好使用导出表。
5) 在新建临时表时,如果一次性插入数据量很大,那么可以使用 select into 代替 create table,避免造成大量 log ,以提高速度;如果数据量不大,为了缓和系统表的资源,应先create table,然后insert。
6) 如果使用到了临时表,在存储过程的最后务必将所有的临时表显式删除,先 truncate table ,然后 drop table ,这样可以避免系统表的较长时间锁定。
7) 尽量避免使用游标,因为游标的效率较差,如果游标操作的数据超过1万行,那么就应该考虑改写。
8) 尽量避免大事务操作,提高系统并发能力。
9) 尽量避免向客户端返回大数据量,若数据量过大,应该考虑相应需求是否合理。
10) 拆分大的 DELETE 或INSERT 语句,批量提交SQL语句。
数据库常用查询语句写法(优化)
标签:速度 ted 强制 column from function 语法 dex 一个