sql语句优化:用join取代not in
2012-11-13 10:17
218 查看
写了好几个页面,速度都上不去,瓶颈在于SQL查询。太多的表,太多的not in,总是从一大推表和数据中筛选出一点数据。看了很多关于SQL优化的文章,都强烈要求不要太多使用not in查询,最好用表连接来取代它。如:
select ID,name from Table_A where ID not in (select ID from Table_B)
这句是最经典的not in查询了。改为表连接代码如下:
select Table_A.ID,Table_A.name from Table_A left join Table_B on Table_A.ID=Table_B.ID and Table_B.ID is null
或者:
select Table_A.ID,Table_A.name from Table_A left join Table_B on Table_A.ID=Table_B.ID where Table_B.ID is null
经试用,效果立竿见影。
select ID,name from Table_A where ID not in (select ID from Table_B)
这句是最经典的not in查询了。改为表连接代码如下:
select Table_A.ID,Table_A.name from Table_A left join Table_B on Table_A.ID=Table_B.ID and Table_B.ID is null
或者:
select Table_A.ID,Table_A.name from Table_A left join Table_B on Table_A.ID=Table_B.ID where Table_B.ID is null
经试用,效果立竿见影。
相关文章推荐
- sql语句优化:用join取代not in (转载)
- sql语句优化:用join取代not in
- sql语句优化:用join取代not in
- SQLServer 优化SQL语句 in 和not in的替代方案
- SQL语句的并集UNION,交集JOIN(内连接,外连接),交叉连接(CROSS JOIN笛卡尔积),差集(NOT IN)
- SQL语句的并集UNION,交集JOIN(内连接,外连接),交叉连接(CROSS JOIN笛卡尔积),差集(NOT IN)
- SQL语句的并集UNION,交集JOIN(内连接,外连接),交叉连接(CROSS JOIN笛卡尔积),差集(NOT IN)
- SQLServer 优化SQL语句 in 和not in的替代方案
- [转]SQL语句的并集UNION,交集JOIN(内连接,外连接),交叉连接(CROSS JOIN笛卡尔积),差集(NOT IN)
- sql语句优化之not in
- Mysql中的STRAIGHT_JOIN和force index语句对sql的优化
- 优化SQL语句:in 和not in的替代方案
- SQLServer 优化SQL语句:in 和not in的替代方案
- SQL语句的并集UNION,交集JOIN(内连接,外连接),交叉连接(CROSS JOIN笛卡尔积),差集(NOT IN)
- sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句
- 优化SQL 语句 in 和not in 的替代方案
- sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句
- sql语句优化--用EXISTS替代IN、用NOT EXISTS替代NOT IN
- 优化SQL语句:in 和not in的替代方案
- SQL语句中的NOT IN 的优化