Sql 2008 Study for one ------INTERSECT AND EXCEPT Remark Set NOCount OFF/ON
来源:互联网 发布:php分页固定套路 编辑:程序博客网 时间:2024/06/09 13:49
最近由于用到sql 比较多,发现自己对sql server 居然一窍不通,所以做做笔记认真学习。例子是sqlserver2008高级编程的。
CREATE TABLE UnionTest1( idcol int IDENTITY, col2 char(3),);CREATE TABLE UnionTest2( idcol int IDENTITY, col4 char(3),);INSERT INTO UnionTest1VALUES ('AAA'), ('BBB'), ('CCC');INSERT INTO UnionTest2VALUES ('CCC'), ('DDD'), ('EEE');PRINT 'Source and content of both tables:';PRINT '';SELECT 1 AS SourceTable, col2 AS ValueFROM UnionTest1UNION ALLSELECT 2, col4FROM UnionTest2;----------------------------------------PRINT 'Results with classic UNION';SELECT col2 FROM UnionTest1UNIONSELECT col4FROM UnionTest2;-----------------------------------------PRINT 'Results with EXCEPT';PRINT '--------------------------';SELECT col2 FROM UnionTest1EXCEPTSELECT col4FROM UnionTest2;--------------------------------------------------PRINT 'Equivilent of EXCEPT but using NOT EXISTS';PRINT '--------------------------';SELECT col2FROM UnionTest1 ut1WHERE NOT EXISTS (SELECT col4 FROM UnionTest2 WHERE col4 = ut1.col2);--------------------------------------------------------PRINT 'Results with INTERSECT';PRINT '--------------------------';SELECT col2 FROM UnionTest1INTERSECTSELECT col4FROM UnionTest2;---------------------------------------------------------------PRINT 'Equivilent of INTERSECT but using EXISTS';PRINT '--------------------------';SELECT col2FROM UnionTest1 ut1WHERE EXISTS (SELECT col4 FROM UnionTest2 WHERE col4 = ut1.col2);------------------------------------------------------------ Clean up after ourselvesDROP 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这样的话,以达到优化
- EIP、ESP、EBP
- Quartz中在Job类中得到Spring中的WebApplicationContext
- 【数据结构】链式队列 Linked_queue
- Struts2的动态方法调用DMI
- rose 2003 安装破解
- Sql 2008 Study for one ------INTERSECT AND EXCEPT Remark Set NOCount OFF/ON
- java中关键字Synchronized的理解及用法
- 《Windows API巡礼》---GetEnvironmentStrings和GetEnvironmentVariable
- 命令行下查看android sqlit3数据库信息
- 使用VS2010进行QT开发Hello,Qt的实现
- 浅谈多核CPU、多线程与并行计算
- ServletContextListener
- 【算法分析】查找算法:二分查找、顺序查找
- 学习笔记 数据结构 堆结构