詳解SQL EXISTS 運(yùn)算符
EXISTS 運(yùn)算符
EXISTS 運(yùn)算符用于判斷查詢(xún)子句是否有記錄,如果有一條或多條記錄存在返回 True,否則返回 False。
SQL EXISTS 語(yǔ)法
SELECT column_name(s) FROM table_name WHERE EXISTS (SELECT column_name FROM table_name WHERE condition);
演示數(shù)據(jù)庫(kù)
在本教程中,我們將使用 RUNOOB 樣本數(shù)據(jù)庫(kù)。
下面是選自 "Websites" 表的數(shù)據(jù):
+----+--------------+---------------------------+-------+---------+ | id | name | url | alexa | country | +----+--------------+---------------------------+-------+---------+ | 1 | Google | https://www.google.cm/ | 1 | USA | | 2 | 淘寶 | https://www.taobao.com/ | 13 | CN | | 3 | 菜鳥(niǎo)教程 | http://www.runoob.com/ | 4689 | CN | | 4 | 微博 | http://weibo.com/ | 20 | CN | | 5 | Facebook | https://www.facebook.com/ | 3 | USA | +----+--------------+---------------------------+-------+---------+
下面是 "access_log" 網(wǎng)站訪問(wèn)記錄表的數(shù)據(jù):
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 實(shí)例
現(xiàn)在我們想要查找總訪問(wèn)量(count 字段)大于 200 的網(wǎng)站是否存在。
我們使用下面的 SQL 語(yǔ)句:
SELECT Websites.name, Websites.url FROM Websites WHERE EXISTS (SELECT count FROM access_log WHERE Websites.id = access_log.site_id AND count > 200);
執(zhí)行以上 SQL 輸出結(jié)果如下:
EXISTS 可以與 NOT 一同使用,查找出不符合查詢(xún)語(yǔ)句的記錄:
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);
執(zhí)行以上 SQL 輸出結(jié)果如下:
以上就是詳解SQL EXISTS 運(yùn)算符的詳細(xì)內(nèi)容,更多關(guān)于SQL EXISTS 運(yùn)算符的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- MySQL中in與exists的使用及區(qū)別介紹
- 對(duì)比分析MySQL語(yǔ)句中的IN 和Exists
- mysql exists與not exists實(shí)例詳解
- 安裝mysql出錯(cuò)”A Windows service with the name MySQL already exists.“如何解決
- MySQL的子查詢(xún)中FROM和EXISTS子句的使用教程
- MYSQL IN 與 EXISTS 的優(yōu)化示例介紹
- mssql和sqlite中關(guān)于if not exists 的寫(xiě)法
- mysql not in、left join、IS NULL、NOT EXISTS 效率問(wèn)題記錄
- SQL中exists的使用方法
- UCenter info: MySQL Query Error SQL:SELECT value FROM [Table]vars WHERE noteexists
- mysql insert if not exists防止插入重復(fù)記錄的方法
相關(guān)文章
SQL Server 2005數(shù)據(jù)庫(kù)還原錯(cuò)誤的經(jīng)典解決方案
本文主要介紹了一個(gè)SQL Server 2005數(shù)據(jù)庫(kù)還原過(guò)程中的錯(cuò)誤的解決方案,需要的朋友可以參考下2015-08-08SQL學(xué)習(xí)筆記二 創(chuàng)建表、插入數(shù)據(jù)的語(yǔ)句
SQL學(xué)習(xí)筆記二 創(chuàng)建表、插入數(shù)據(jù)的語(yǔ)句,需要的朋友可以參考下。2011-08-08在SQL Server中恢復(fù)多個(gè)數(shù)據(jù)庫(kù)的方法小結(jié)
這篇文章主要介紹了如何在SQL Server中恢復(fù)多個(gè)數(shù)據(jù)庫(kù),通常情況下,只要備份文件的名稱(chēng)與相應(yīng)的數(shù)據(jù)庫(kù)匹配,且沒(méi)有附加的日期或時(shí)間信息,就可以通過(guò)有效的 T-SQL 腳本來(lái)完成恢復(fù),文中給介紹了在SQL Server中恢復(fù)多個(gè)數(shù)據(jù)庫(kù)的方法小結(jié),需要的朋友可以參考下2024-09-09SqlServer應(yīng)用之sys.dm_os_waiting_tasks 引發(fā)的疑問(wèn)(下)
這篇文章主要介紹了SqlServer應(yīng)用之sys.dm_os_waiting_tasks 引發(fā)的疑問(wèn)(下) 的相關(guān)資料,需要的朋友可以參考下2015-12-12mssql server 數(shù)據(jù)庫(kù)附加不上解決辦法分享
在我們做開(kāi)發(fā)中經(jīng)常會(huì)對(duì)數(shù)據(jù)庫(kù)進(jìn)行備份,但有時(shí)假就會(huì)出現(xiàn)數(shù)據(jù)庫(kù)附加不上問(wèn)題,下面我們來(lái)看看一個(gè)朋友的解決辦法2011-09-09使用FORFILES命令來(lái)刪除SQLServer備份的批處理
利用這些參數(shù)可以構(gòu)造下面的例子來(lái)解決你刪除備份腳本文件的難題。你可以基于更改時(shí)間/日期或者備份類(lèi)型來(lái)創(chuàng)建腳本。你甚至可以構(gòu)造能夠同時(shí)參照兩種標(biāo)準(zhǔn)的腳本2012-05-05SQL Server降權(quán)運(yùn)行 SQL Server 2000以GUESTS權(quán)限運(yùn)行設(shè)置方法
由于sql注入問(wèn)題比較常見(jiàn),很多黑客都是通過(guò)sqlserver數(shù)據(jù)庫(kù)漏洞直接獲取系統(tǒng)權(quán)限,所以sqlserver的安全設(shè)置尤為重要,簡(jiǎn)單簡(jiǎn)單分享下sqlserver低權(quán)限運(yùn)行方法2014-07-07