• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

MySQL数据库中如何进行子查询

mysql 搞代码 4年前 (2022-01-09) 16次浏览 已收录 0个评论

子查询是将一个查询语句嵌套在另一个查询语句中,内层查询语句的查询结果,可以作为外层查询语句提供查询条件。子查询中可能包括IN、NOT IN、ANY、ALL、EXISTS和NOT EXISTS等关键字,还包括比较运算符,如“=”、“!=”等,那如何进行子查询,具体操作如下:

1.首先,在一个查询中的查询结果作为外层查询的条件,可以用IN关键字,代码如下:

SELECT * FROM city WHERE CountryCode IN (SELECT Code FROM country);

如下图所示:

2.其次,外层查询的条件不在内层查询结果,可以用NOT IN关键字,代码如下:

SELECT * FROM city WHERE CountryCode NOT IN (SELECT Code FROM country);

如下图所示:

3.使用EXISTS关键字查询时,内层查询语句不返回查询的记录,而是返回一个Boolean值;当内层查询返回的值为true时,外层查询语句将进行查询,如果返回false时,将不进行查询或查本文来源gao@!dai!ma.com搞$$代^@码!网!询结果为空,代码如下:

SELECT * FROM city WHERE EXISTS (SELECT Name FROM country);

如下图所示:

4.由第三步可知,与EXISTS相对的是NOT EXISTS,当内层查询返回的值为false时,外层查询语句将进行查询,如果返回true时,将不进行查询或查询结果为空,代码如下:

SELECT * FROM city WHERE NOT EXISTS (SELECT Name FROM country);

如下图所示:

5.满足其中的任一条件,就可以通过该条件来执行外层查询语句,用关键字ANY,代码如下:

SELECT * FROM city WHERE Population >= ANY (SELECT Population FROM country);

如下图所示:

6.子查询还包含比较运算符,有“>="、“<="、"!="等关键字,代码如下:

SELECT * FROM city WHERE Population >=  (SELECT Population FROM country WHERE Name = 'Afghanistan');SELECT * FROM city WHERE Population <=  (SELECT Population FROM country WHERE Name = 'Afghanistan');SELECT * FROM city WHERE Population !=  (SELECT Population FROM country WHERE Name = 'Afghanistan');

如下图所示:

7.满足所有条件,只有满足内层查询语句返回所有结果,代码如下:

SELECT * FROM city WHERE Population >= ALL (SELECT Population FROM country WHERE Name = 'Afghanistan');

如下图所示:

注意事项

注意子查询的用法

注意子查询中各个关键字的区别

以上就是MySQL数据库中如何进行子查询的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:MySQL数据库中如何进行子查询

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址