SQL查询语句优化的一点

发表于:2007-05-25来源:作者:点击数: 标签:sql优化一点Insert查询

(1) INSERT [INTO] B SELECT id, field1, field2 FROM A WHERE NOT EXISTS (SELECT id FROM B WHERE id=[A.]id) 

(2) INSERT [INTO] B SELECT * FROM A WHERE id NOT IN (SELECT id FROM B)

---------------------------------------------------------------------------

这两句,都是将 A 表中存在, 但B表中不存在的数据, 插入到B表中, 关联比较字段为 id.
但这两句的执行效率,却是有数量级的差别.

结论有两点:

  1. 尽量用 EXISTS 和 NOT EXISTS 代替 IN 和 NOT IN
  2. 不要偷懒, 尽量不用 SELECT * FROM ...., 而要写字段名 SELECT field1,field2,.... 

原文转自:http://www.ltesting.net