图1使用intersect操作符查询的结果
第二种方法: in子句
in子句可以在子查询中为where子句计算所得的值创建一个列表。这种方法与前一种方法有所不同的是,前一种方法比较多列但只使用一个intersect就行了,而一个in子句用来比较两个子查询的一列,比较几列就要使用几个in子句。下面举例说明如何取得两个查询的交集。
仍以A和B两张数据表为例,在oracle中运行以下查询,图2显示了这个查询的结果:
SQLselect code,name from Awhere A.code in(select student_code from B)and A.name in(select student_name from B)order by A.code;
查询结果如图2所示。
图2使用in子句查询的结果
以上为笔者使用oracle7.3的体会,如有不当之处,请不吝赐教。