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;