详解SQL EXISTS 运算符

 更新时间:2020年07月17日 09:39:37   作者:菜鸟教程  
这篇文章主要介绍了SQL EXISTS 运算符的相关资料,文中详细的讲述了SQL EXISTS 运算符的语法与用法,实例帮助大家更好的理解和学习,感兴趣的朋友可以了解下

EXISTS 运算符

EXISTS 运算符用于判断查询子句是否有记录,如果有一条或多条记录存在返回 True,否则返回 False。

SQL EXISTS 语法

SELECT column_name(s)
FROM table_name
WHERE EXISTS
(SELECT column_name FROM table_name WHERE condition);

演示数据库

在本教程中,我们将使用 RUNOOB 样本数据库。

下面是选自 "Websites" 表的数据:

+----+--------------+---------------------------+-------+---------+
| id | name     | url            | alexa | country |
+----+--------------+---------------------------+-------+---------+
| 1 | Google    | https://www.google.cm/  | 1   | USA   |
| 2 | 淘宝    | https://www.taobao.com/  | 13  | CN   |
| 3 | 菜鸟教程 | http://www.runoob.com/  | 4689 | CN   |
| 4 | 微博    | http://weibo.com/     | 20  | CN   |
| 5 | Facebook   | https://www.facebook.com/ | 3   | USA   |
+----+--------------+---------------------------+-------+---------+

下面是 "access_log" 网站访问记录表的数据:

mysql> SELECT * FROM access_log;
+-----+---------+-------+------------+
| aid | site_id | count | date    |
+-----+---------+-------+------------+
|  1 |    1 |  45 | 2016-05-10 |
|  2 |    3 |  100 | 2016-05-13 |
|  3 |    1 |  230 | 2016-05-14 |
|  4 |    2 |  10 | 2016-05-14 |
|  5 |    5 |  205 | 2016-05-14 |
|  6 |    4 |  13 | 2016-05-15 |
|  7 |    3 |  220 | 2016-05-15 |
|  8 |    5 |  545 | 2016-05-16 |
|  9 |    3 |  201 | 2016-05-17 |
+-----+---------+-------+------------+
9 rows in set (0.00 sec)

SQL EXISTS 实例

现在我们想要查找总访问量(count 字段)大于 200 的网站是否存在。

我们使用下面的 SQL 语句:

SELECT Websites.name, Websites.url 
FROM Websites 
WHERE EXISTS (SELECT count FROM access_log WHERE Websites.id = access_log.site_id AND count > 200);

执行以上 SQL 输出结果如下:

EXISTS 可以与 NOT 一同使用,查找出不符合查询语句的记录:

SELECT Websites.name, Websites.url 
FROM Websites 
WHERE NOT EXISTS (SELECT count FROM access_log WHERE Websites.id = access_log.site_id AND count > 200);

执行以上 SQL 输出结果如下:

以上就是详解SQL EXISTS 运算符的详细内容,更多关于SQL EXISTS 运算符的资料请关注脚本之家其它相关文章!

相关文章

  • SQL如何实现横表与纵表相互转换

    SQL如何实现横表与纵表相互转换

    针对SQL横向表转纵向的问题,本文从实际应用出发,详细讲解了语法和操作步骤,并结合实例进行了演示和说明。文章还探讨了该方法的优缺点,提出了一些值得注意的事项,旨在帮助读者更深入地理解这一重要的数据处理技巧
    2023-04-04
  • 隐藏在SQLServer 字段中的超诡异字符解决过程

    隐藏在SQLServer 字段中的超诡异字符解决过程

    这套系统做了大半年,这个导入导出还是问题不断,我负责的这块导入导出就是夹在网络版和单机版系统之间,只要任何一边对数据库做了改动这个导入导出就会失败。哎,烦心的事不止这些,最近又遇到了一个非常奇怪的问题。
    2009-10-10
  • 使用用SQL语句从电脑导入图片到数据库的方法

    使用用SQL语句从电脑导入图片到数据库的方法

    这篇文章主要介绍了用SQL语句从电脑导入图片到数据库的方法,文中给大家提到了从MySQL数据库读取图片和向数据库插入图片的代码,需要的朋友可以参考下
    2019-09-09
  • 多表关联同时更新多条不同的记录方法分享

    多表关联同时更新多条不同的记录方法分享

    因为项目要求实现一次性同时更新多条不同的记录的需求,和同事讨论了一个比较不错的方案,这里供大家参考下
    2011-10-10
  • sql使用cast进行数据类型转换示例

    sql使用cast进行数据类型转换示例

    这篇文章主要介绍了sql使用cast进行数据类型转换,需要的朋友可以参考下
    2014-03-03
  • 编写SQL需要注意的细节Checklist总结

    编写SQL需要注意的细节Checklist总结

    本周技术研究部(TRD)的一名DBA 对我们编写SQL时的一些问题,进行了汇报讲演,以下是来自它的脚本,我在它讲演的基础上写出了自己想表述的,以便于大家相互交流学习
    2012-08-08
  • SqlServer类似正则表达式的字符处理问题

    SqlServer类似正则表达式的字符处理问题

    这篇文章主要介绍了SqlServer类似正则表达式的字符处理问题,需要的朋友可以参考下
    2017-10-10
  • 配置 SQL Server 2005 以允许远程连接的方法

    配置 SQL Server 2005 以允许远程连接的方法

    在尝试从远程计算机连接到 Microsoft SQL Server 2005 实例时,可能会接收到错误消息。在使用任何程序连接到 SQL Server 时都可能会发生此问题。
    2011-01-01
  • Sql Server 视图数据的增删改查教程

    Sql Server 视图数据的增删改查教程

    这篇文章主要介绍了Sql Server 视图数据的增删改查教程,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • SQL查询服务器硬盘剩余空间

    SQL查询服务器硬盘剩余空间

    这篇文章主要介绍了SQL查询服务器硬盘剩余空间的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-08-08

最新评论