SET NOCOUNT ON, SET NOCOUNT OFF
当 SET NOCOUNT 为 ON 时,不返回计数(表示受 Transact-SQL 语句影响的行数)。
当 SET NOCOUNT 为 OFF 时,返回计数。
如果存储过程中包含的一些语句并不返回许多实际的数据,则该设置由于大量
减少了网络流量,因此可显著提高性能。
SQL 中 IN 和 EXISTS 用法的区别
NOT IN
SELECT DISTINCT MD001 FROM BOMMD WHERE MD001 NOT IN (SELECT MC001
FROM BOMMC)
NOT EXISTS,exists 的用法跟 in 不一样,一般都需要和子表进行关联,而且关联时,需要
用索引,这样就可以加快速度
select DISTINCT MD001 from BOMMD WHERE NOT EXISTS (SELECT MC001 FROM
BOMMC where BOMMC.MC001 = BOMMD.MD001)
exists 是用来判断是否存在的,当 exists(查询)中的查询存在结果时则返回真,否则返回
假。not exists 则相反。
exists 做为 where 条件时,是先对 where 前的主查询询进行查询,然后用主查询的结果
一个一个的代入 exists 的查询进行判断,如果为真则输出当前这一条主查询的结果,否则
不输出。
in 和 exists
in 是把外表和内表作 hash 连接,而 exists 是对外表作 loop 循环,每次 loop 循环再对内表
进行查询。一直以来认为 exists 比 in 效率高的说法是不准确的。
如果查询的两个表大小相当,那么用 in 和 exists 差别不大。
如果两个表中一个较小,一个是大表,则子查询表大的用 exists,子查询表小的用
in:
例如:表 A(小表),表 B(大表)1:select * from A where cc in (select cc from B)
效率低,用到了 A 表上 cc 列的索引;select * from A where exists(select cc from B where
cc=A.cc)
效率高,用到了 B 表上 cc 列的索引。
相反的 2:select * from B where cc in (select cc from A)
效率高,用到了 B 表上 cc 列的索引;select * from B where exists(select cc from A where
cc=B.cc)
效率低,用到了 A 表上 cc 列的索引。
not in 和 not exists 如果查询语句使用了 not in 那么内外表都进行全表扫描,没有用到索引;
而 not extsts 的子查询依然能用到表上的索引。所以无论那个表大,用 not exists 都比 not
in 要快。
in 与 =的区别