设为首页 友情链接
在线留言 发表文章
加入收藏 广告联系

刺猬首页

| 专案技术 | 网络技术 | 图形图象 | 网络编程 | 网页设计 | 操作系统 | 服务器 | 技术白皮书 | 在线实验室 | 刺猬论坛 |
小说专版  | 数据库 | 设计赏析 | 存储频道 | 网络安全 | 私服架设 |  Solaris | 网站评估 | PC维护技巧 | 下载中心 | 博 客 |
专   题: | Linux | java | cisco | 防病毒 | 刀片 | SOA | iscsi | ASP.NET | SQL | Oracle |
您现在的位置: IT公社 IT community >> 数据库应用 >> Oracle >> 教程正文 用户登录 新用户注册
专 题 栏 目
最 新 热 门
最 新 推 荐
相 关 文 章
谈SQL Server 2005中的T…
在T-SQL实现Oracle的MIN…
从Oracle到SQL Server-S…
Oracle中如何用T-SQL语句…
Oracle中如何用T-SQL语句…
简单介绍:MS-SQL数据库…
学习-SQL查询连续号码段…
数据库漏洞:MS SQL-SER…
从Oracle到Sql Server--…
浅谈SQL SERVER 2000 T-…
  在T-SQL实现Oracle的MINUS集合运算符         
在T-SQL实现Oracle的MINUS集合运算符
 

SQL语言中的MINUS(减法)集合运算符是非常重要的。找到两个给定的数值集合之间的差异,意味着找到一个数值集合,其中的元素仅存在于前一个集合中,而不存在于另一个集合中,这项操作是一个很常见,也非常重要的操作,特别是在处理数据库图表发生结构性的变化的时候。

这项操作在以下情况中非常有用:当你想标识哪些列被添加或者删除时,或者当你改变了表中的初始值,并想了解两个图表中的数据差别时。

例如,在测试和产品环境中。这个运算符存在于Oracle SQL中,但是很不幸运的是,它不存在于SQL Server 2000 SQL中。这里我描述一下使用T-SQL工具实现功能稍弱一点的MINUS运算符的方法。

我编写了一个名为sp_Minus的程序,这个程序执行两个查询,并找出他们之间的差别。当结果集中只出现了一个列时,会出现意外情况,它实际上使得这个程序成为一个MINUS向量操作,而不是一个集合操作。这是因为我使用了NOT IN运算符,它只作用于一个列,而不是一些列的集合。这个程序在两个select(选择)语句中安置了一个INTO子句,并构建了两个全局临时表来存储中间结果。然后使用一个NOT IN子句在这两个表上执行MINUS运算符动作,最终生成一个MINUS向量结果。

下面是程序代码:

CREATE Procedure sp_MINUS (@query1 varchar(2000),

@query2 varchar(2000))

As

Begin



Declare @buildStmt1 varchar(2000)

Declare @buildStmt2 varchar(2000)

Declare @pos1 int

Declare @pos2 int 



Set nocount on 

Set @pos1 = charindex ('FROM',upper (@query1))

Set @pos2 = charindex ('FROM',upper (@query2))



-- 在语句中输入into 子句



Set @buildStmt1 = SUBSTRING (@query1,1,@pos1-1) + 

' as f into ##t1 ' + 

SUBSTRING (@query1,@pos1,len(@query1) - @pos1 + 1)



Set @buildStmt2 = SUBSTRING (@query2,1,@pos2-1) + 

' as f into ##t2 ' + 

SUBSTRING (@query2,@pos2,len(@query2) - @pos2 + 1)



-- 构建中间全局临时表



EXEC (@buildStmt1)

EXEC (@buildStmt2)





-- 执行MINUS操作



Select f from ##t1 

Where f NOT in (select f from ##t2)



-- 删除表



Drop table ##t1

Drop table ##t2

Set nocount off 

End 



Go

以上程序测试成功,有兴趣的可以试试。

Linux联盟收集整理

频道声明:本频道的文章除部分特别声明禁止转载的专稿外,可以自由转载.但请务必注明出出处和原始作者 文章版权归本频道与文章作者所有.对于被频道转载文章的个人和网站,我们表示深深的谢意。

原始作者:佚名 录入时间:2007-1-3 3:08:05
信息来源:不详 投稿信箱:itqoo@126.com
教程录入:itqoo    责任编辑:itqoo 
  • 上一个教程:

  • 下一个教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    - 关于我们 - 合作伙伴 - 友情链接 - 广告刊登 - 投稿热线 - 在线留言版权声明联系方式 -
    IT公社版权所有 粤ICP备05127012号
    Copyrigh@2005-2006 itqoo.com.Inc All Rights Reserved  推荐分辨率 1024*768
    联系站长:E-Mail:itqoo@126.com     MSN:urchincc@hotmail.com    QQ:点击这里给我发消息
    特别感谢:亿太网络提供空间支持