Chinaunix首页 | 论坛 | 博客
  • 博客访问: 92606690
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类: Oracle

2008-04-07 21:37:28

     来源:赛迪网技术社区    作者:dizeli

Oracle关系型数据库管理系统是世界上流行的关系数据库,它是一个极其强大、灵活和复杂的系统,据说,在使用Oracle时应有这样的思想,那就是在SQL中几乎可以实现任何一种想法。

下面向大家介绍使用SQL查两个Oracle数据表查询的相同数据的方法,笔者感到这两种方法执行效率高、使用方便。

第一种方法:利用操作符intersect

intersect操作符用来合并两个查询,返回两个查询中都存在的记录,即返回两个查询结果的交集,前提是两个查询的列的数量和数据类型必须完全相同。

举例说明:

表A的数据结构

   

表B的数据结构

表A的数据为:

('1101 ','韩甲'),('1102 ','丁乙')

表B的数据为:

('1101 ','韩甲',99),('1102 ','丁乙',89),('1103 ','徐静',94)

在oracle中运行以下查询,图1显示了这个查询的结果:

  SQL>select code, name from A
  intersect select student_code,student_name from B;

   

图1 使用intersect操作符查询的结果

第二种方法: in子句

in子句可以在子查询中为where子句计算所得的值创建一个列表。这种方法与前一种方法有所不同的是,前一种方法比较多列但只使用一个intersect就行了,而一个in子句用来比较两个子查询的一列,比较几列就要使用几个in子句。下面举例说明如何取得两个查询的交集。

仍以A和B两张数据表为例,在oracle中运行以下查询,图2显示了这个查询的结果:

  SQL>select code,name from A
  where A.code in 
  (select student_code from B)
  and A.name in
  (select student_name from B)
  order by A.code;
  

查询结果如图2所示。

  

图2使用in子句查询的结果 
阅读(145) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~