如何优化sql查询

借鉴https://www.cnblogs.com/ssrstm/p/5753068.htmlhttps://www.cnblogs.com/exe19/p/5786806.html

1.  对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。

2.  应尽量避免在 where 子句中对字段进行 null 值判断,应尽量避免在 where 子句中使用!=或<>操作符,应尽量避免在 where 子句中使用 or 来连接条件因为以上的查询会导致导致引擎放弃使用索引而进行全表扫描。

3.  in 和 not in 也要慎用,否则会导致全表扫描。

4.  SELECT子句中避免使用‘*’:

5.  尽量多使用COMMIT:只要有可能,在程序中尽量多使用COMMIT, 这样程序的性能得到提高,需求也会因为COMMIT所释放的资源而减少,COMMIT所释放的资源:

   a. 回滚段上用于恢复数据的信息。

   b. 被程序语句获得的锁。

   c. redo log buffer 中的空间。

   d. Oracle为管理上述3种资源中的内部花费。

6.  通过内部函数提高SQL效率

7.  避免在where 字句中使用参数,对字段进行表达式操作,对字段进行函数操作,“=”左边进行函数、算术运算或其他表达式运算,因为会导致引擎放弃使用索引而进行全表扫描。

8.  尽量避免使用游标

9.  删除重复记录

转载于:https://www.cnblogs.com/jkzr/p/10697541.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值