Sql 2008 Study for one ------INTERSECT AND EXCEPT Remark Set NOCount OFF/ON

最近由于用到sql 比较多,发现自己对sql server 居然一窍不通,所以做做笔记认真学习。例子是sqlserver2008高级编程的。

CREATE TABLE UnionTest1
(
   idcol   int       IDENTITY,
   col2    char(3),
);

CREATE TABLE UnionTest2
(
   idcol   int       IDENTITY,
   col4    char(3),
);

INSERT INTO UnionTest1
VALUES
   ('AAA'),
   ('BBB'),
   ('CCC');

INSERT INTO UnionTest2
VALUES
   ('CCC'),
   ('DDD'),
   ('EEE');

PRINT 'Source and content of both tables:';
PRINT '';

SELECT 1 AS SourceTable, col2 AS Value
FROM UnionTest1
UNION ALL
SELECT 2, col4
FROM UnionTest2;
----------------------------------------
PRINT 'Results with classic UNION';
SELECT col2 
FROM UnionTest1
UNION
SELECT col4
FROM UnionTest2;
-----------------------------------------
PRINT 'Results with EXCEPT';
PRINT '--------------------------';
SELECT col2 
FROM UnionTest1
EXCEPT
SELECT col4
FROM UnionTest2;
--------------------------------------------------
PRINT 'Equivilent of EXCEPT but using NOT EXISTS';
PRINT '--------------------------';
SELECT col2
FROM UnionTest1 ut1
WHERE NOT EXISTS
  (SELECT col4 FROM UnionTest2 WHERE col4 = ut1.col2);
--------------------------------------------------------
PRINT 'Results with INTERSECT';
PRINT '--------------------------';
SELECT col2 
FROM UnionTest1
INTERSECT
SELECT col4
FROM UnionTest2;
---------------------------------------------------------------
PRINT 'Equivilent of INTERSECT but using EXISTS';
PRINT '--------------------------';
SELECT col2
FROM UnionTest1 ut1
WHERE EXISTS
  (SELECT col4 FROM UnionTest2 WHERE col4 = ut1.col2);
----------------------------------------------------------
-- Clean up after ourselves
DROP TABLE UnionTest1;
DROP TABLE UnionTest2;

SET NOCOUNT OFF; -- Don't forget to turn this back to the default!

 

通过以上的例子可以看出intersect /except 和exists的效果一样,并且相对来说exists的不是很好看,为什么常用exists,因为在实例中的时候exists方法的效率会更胜一筹,所以在开发的时候如何让代码的易于阅读,易于理解,或者时效能更高,这只有在实际的当中自我运用。


SET NOCOUNT  OFF 备注:

当 SET NOCOUNT 为 ON 时,不返回计数(表示受Transact-SQL 语句影响的行数)。 
当 SET NOCOUNT 为 OFF 时,返回计数(默认为OFF)。

即使当 SET NOCOUNT 为 ON 时,也更新 @@ROWCOUNT 函数。

当 SET NOCOUNT 为 ON 时,将不给客户端发送存储过程中的每个语句的 DONE_IN_PROC 信息。当使用 Microsoft® SQL Server™ 提供的实用工具执行查询时,在 Transact-SQL 语句(如 SELECT、INSERT、UPDATE 和 DELETE)结束时将不会在查询结果中显示"nn  行受影响"。

如果存储过程中包含的一些语句并不返回许多实际的数据,则该设置由于大量减少了网络流量,因此可显著提高性能。

SET NOCOUNT 设置是在执行或运行时设置,而不是在分析时设置。

注释当SET NOCOUNT 为ON 时,不返回计数(表示受Transact-SQL 语句影响的行数)。当SET NOCOUNT 为OFF 时,返回计数。 ... 结论:我们应该在存储过程的头部加上SET NOCOUNT ON 这样的话,在退出存储过程的时候加上SET NOCOUNT OFF这样的话,以达到优化



 


 

 

 


 

 

 

 

你可能感兴趣的:(sql,sql,server,Microsoft,table,insert,sqlserver)