sql问题整理(不定时更新)

本文介绍了SQL查询优化的关键技术,包括LIKE语句的优化方法、ORDER BY子句的使用技巧及异常情况处理,还对比了NOT EXISTS与NOT IN的区别,帮助读者提高SQL查询效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

like 优化
    半个%能够使用索引
    覆盖索引: select中展示索引 , where查找索引值
order优化 
    覆盖索引

异常:
    left join 查询结果集数量大于原数据集 ( 原因 : 关联关系中存在1对多关系[1:n] )

sqlSERVER中 NOT EXISTS 与 NOT IN区别

   NOT EXISTS调用子查询时top 等统计会忽略 , NOT IN会使用
   NOT IN如果子查询中返回的任意一条记录含有空值,则查询将不返回任何记录。如果子查询字段有非空限制,这时可以使用not in,并且可以通过提示让它用hasg_aj或merge_aj连接。
   如果查询语句使用了not in,那么对内外表都进行全表扫描,没有用到索引;而not exists的子查询依然能用到表上的索引。所以无论哪个表大,用not exists都比not in 要快。
   如果查询的两个表大小相当,那么用in和exists差别不大;如果两个表中一个较小一个较大,则子查询表大的用exists,子查询表小的用in;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值