当前位置: 首页 > 图文教程 > 数据库 > Oracle > Oracle对两个数据表交集的查询

Oracle
浅谈Oracle数据库SCN号
浅谈DBMS_SCHEDULER如何使用
数据丢失 Oracle闪回
Oracle教程:完全备份的SH文件
Oracle服务器参数文件管理技巧
Oracle认证:向视图中插入数据的方法
Oracle教程:Oracle基础知识整理
使用Java和oracle实现BLOB字段的字符串读取
Oralce 9i安装OID目录服务器说明
Oracle 11gR2重要的4个新特性说明
OpenCalais:为Oracle数据库添加语义元数据为Oracle数据库添加语义元数据
phpBB 3.0.6 RC1简单介绍和下载
Oracle:oracle的体系结构,你了解多少?
怎样才能限制SQL Server只能让指定的机器连接
有关Oracle数据库的备份情况
ORACLE8的分区管理
常见数据库系统之比较 - Oracle数据库
在ORACLE中移动数据库文件
ORACLE常见错误代码的分析与解决(三)
Oracle中如何直接运行OS命令(上)

Oracle对两个数据表交集的查询


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 143 ::
收藏到网摘: n/a

正在看的ORACLE教程是:Oracle对两个数据表交集的查询。

Oracle关系型数据库管理系统是世界上流行的关系数据库,它是一个极其强大、灵活和复杂的系统,据说,在使用oracle时应有这样的思想,那就是在SQL中几乎可以实现任何一种想法。
  下面向大家介绍使用SQL查两个Oracle数据表查询的相同数据的方法,笔者感到这两种方法执行效率高、使用方便。
  第一种方法:利用操作符intersect
  intersect操作符用来合并两个查询,返回两个查询中都存在的记录,即返回两个查询结果的交集,前提是两个查询的列的数量和数据类型必须完全相同。
  举例说明:
  表A的数据结构:

  表B的数据结构:

  表A的数据为:
  ('1101 ','韩甲'),('1102 ','丁乙')
  表B的数据为:
  ('1101 ','韩甲',99),('1102 ','丁乙',89),('1103 ','徐静',94)
  在oracle中运行以下查询,图1显示了这个查询的结果:

[NextPage]

第二种方法: in子句
  in子句可以在子查询中为where子句计算所得的值创建一个列表。这种方法与前一种方法有所不同的是,前一种方法比较多列但只使用一个intersect就行了,而一个in子句用来比较两个子查询的一列,比较几列就要使用几个in子句。下面举例说明如何取得两个查询的交集。
  仍以A和B两张数据表为例,在oracle中运行以下查询,图2显示了这个查询的结果:

  查询结果如图2所示。

  以上为笔者使用oracle7.3的体会,如有不当之处,请不吝赐教。

上一页