sql合并查询实例 sql子查询教程

发布时间:2019-09-09编辑:脚本学堂
本文介绍了sql语句实现合并查询的例子,sql子查询的用法,一个选择查询安置在另一个查询内部,创建一个在单一声明搜索中不可用的资源,子选择允许查询的合并,结果组比较的责任落到了数据库中而不是应用软件代码中。

sql合并查询实例教程

sql子查询可以在一组结果中查询,创造性地给结果组加以限定,或在向数据库的单一调用中将结果与一个无关系的查询做相关。
以下通过几个子选择的例子并就何时使用他们进行讨论。

一,在一个结果组中搜索

子选择的理念很简单:
一个选择查询安置在另一个查询内部,创建一个在单一声明搜索中不可用的资源。
子选择允许查询的合并,结果组比较的责任落到了数据库中而不是应用软件代码中。

使用这个功能的一个途径是对两个表格中的可比数据专栏中的值进行定位。例如,我的一个数据库有两个表格,Album和Lyric。我可以很容易地通过下面的子查询声明来找到每一个Metallica的歌曲中包含“justice”的歌名:
 

复制代码 代码示例:
select song_name from album
  where band_name = ‘metallica’
  and song_name in
  (select song_name from lyric
  where song_lyric like ‘%justice%’);
 

例子很简单,从Album表格中选择了所有Metallica的歌曲,接着,在lyric表格中选择所有包含“justice”的歌曲,最后,使用IN关键字来从Lyric表格结果组中显示的Album表格中返回歌曲名称。

使用Lyric表格结果组来给Album表格中的结果做限定。WHERE子句中的子选择部分是完全自包含的,因此不需要使用例如Album.song_name和Lyric.song_name等完整的专栏名称。
没有从最终结果组的Lyric表格中返回任何值,如果需要歌曲的Lyric,会使用一个JOIN声明。(www.jb200.com 脚本学堂)

二,使用not in排除结果

可以使用NOT IN关键字来获得明确地不被包含在另一个结果组中的结果。
例如,想要通过以下代码来返回Metallica在“And Justice for All”专辑中不包含单词“justice”的歌曲:
 

复制代码 代码示例:
select song_name from album
  where album_name = ‘and justice for all’
  and band_name = ‘metallica’
  and song_name not in
  (select song_name from lyric
  where song_lyric like ‘%justice%’);
 

在前面的SQL代码中,选择了Metallica的“And Justice for All,”专辑中的所有歌曲,接着是带有歌词中带有“justice”所有歌曲,最后从在Lyric结果组中没有出现的Album结果组返回了所有歌曲。较之于返回两个查询并使用代码来比较数组,你通过一个单独的声明就可以得到确切的结果。

三,使用EXISTS来相关结果
有时可以通过多种途径来访问相同的数据,而且需要对你的结果进行匹配(或相关)来得到值的交叉区。
例如,可以通过搜索Album表格来得到Metallica的歌曲列表,可是,也可以从我的Cover表格中得到由Damage, Inc表演的Metallica的歌曲的列表,可以在两个表格中直接比较查询结果来对值作相关。

例子:
 

复制代码 代码示例:
select album.song_name from album
  where album.band_name = ‘metallica’
  and exists
  (select cover.song_name from cover
  where cover.band_name = ‘damage, inc.’
  and cover.song_name = album.song_name);
 

在SQL代码中,使用完整的专栏名称,这是因为直接对两个表格作比较,而不仅仅是将结果组作为一个被动资源来使用。
并不从Cover表格中返回结果。一些数据库支持NOT EXISTS关键字来确保你并没有匹配。

四,使用合计函数来比较
除了使用子选择在相关的表格中检查数据,还可以在一个WHERE子选择中使用合计函数来确定主结果组。
例如,要核实每一个Metallica歌曲在Album表格中的条目。
而且,还想返回缺少歌曲的专辑的名称。很方便地,AlbumInfo表格包含的一个专栏(album_tracks)给出了应该有多少首歌曲方面的信息。
例子:
 

复制代码 代码示例:
select albuminfo.album_name from albuminfo
  where albuminfo.band_name = ‘metallica’
  and album_tracks <>
  (select count(*) from album
  where album.album_name = albuminfo.album_name);
 

现在已成功地返回了所有Metallica的专辑中,应有的曲目数量与Album表格中实际的歌曲条目数量不符的专辑名称。

五,返回子选择结果
如果还是关心每一张专辑的曲目数量并需要得到一个比较报告怎么办?
可以将一个子选择的结果作为最终结果组的一部分来返回。
这个功能经常被合计函数所使用。
通常地,对其他表格的访问可以作为你的查询的一部分。

下一个例子将返回每一张Metallica的专辑,应该包括的曲目数量和在Album表格中包括的条目数量:
 

复制代码 代码示例:
select albuminfo.album_name, album_tracks,
  (select count(*) from album
  where album.album_name = albuminfo.album_name)
  from albuminfo
  where albuminfo.band_name = ‘metallica’;

另一个强有力的例子涉及了在AlbumInfo表格中将album_tracks值改变为在Album表格中实际的条目数量:
 

复制代码 代码示例:
update albuminfo set album_tracks =
  select count(*) from album
  where albuminfo.album_name = album.album_name)
  where albuminfo.band_name = ‘metallica’;
 

在上两个例子中的子选择声明被看作一个自包含单位来执行。

六,子选择比较关键字(ALL, SOME, ANY)

除了使用标准查询功能,还有三个关键字可以使你将一个表达式值和一个单栏子选择声明结果组作比较,这些关键字返回TRUE或FALSE的Boolean值。
ALL关键字要求子选择中所有值都遵守比较运算符。SOME和ANY关键字则要求至少一对。
这里是ALL关键字的一个简单实例。

例子:
 

复制代码 代码示例:
SELECT * FROM AlbumSales
  WHERE album_gross >
  ALL (SELECT album_costs FROM AlbumProduction);

以上的例子将从AlbumSales表格返回在AlbumProduction表格里面付出总额大于成本而生产最昂贵的专辑的所有记录。
如果用ANY替代ALL,声明将返回所有付出总额大于最低专辑成本的专辑记录。
声明= ANY与IN关键字意义是相同的。声明<> ALL与NOT IN关键字是对等的。关键字ANY和SOME也是等同的。
数据库生产商中对这些关键字的支持情况是不同的,因此在出现问题时要相信查阅生产商方面的资料。