国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > MySQL > 正文

MySQL exists 和in 詳解及區(qū)別

2024-07-24 13:11:52
字體:
供稿:網(wǎng)友

MySQL exists 和in10/129042.html">inux/141744.html">in 詳解及區(qū)別

有一個(gè)查詢?nèi)缦拢?/p>

SELECT c.CustomerId, CompanyName  FROM Customers c  WHERE EXISTS(   SELECT OrderID FROM Orders o   WHERE o.CustomerID = cu.CustomerID)  

這里面的EXISTS是如何運(yùn)作呢?子查詢返回的是OrderId字段,可是外面的查詢要找的是CustomerID和CompanyName字段,這兩個(gè)字段肯定不在OrderID里面啊,這是如何匹配的呢?

EXISTS用于檢查子查詢是否至少會(huì)返回一行數(shù)據(jù),該子查詢實(shí)際上并不返回任何數(shù)據(jù),而是返回值True或False。

EXISTS 指定一個(gè)子查詢,檢測(cè)行的存在。語(yǔ)法:EXISTS subquery。參數(shù) subquery 是一個(gè)受限的 SELECT 語(yǔ)句 (不允許有 COMPUTE 子句和 INTO 關(guān)鍵字)。結(jié)果類型為 Boolean,如果子查詢包含行,則返回 TRUE。

在子查詢中使用 NULL 仍然返回結(jié)果集

這個(gè)例子在子查詢中指定 NULL,并返回結(jié)果集,通過使用 EXISTS 仍取值為 TRUE。

SELECT CategoryNameFROM CategoriesWHERE EXISTS (SELECT NULL)ORDER BY CategoryName ASC

比較使用 EXISTS 和 IN 的查詢

這個(gè)例子比較了兩個(gè)語(yǔ)義類似的查詢。第一個(gè)查詢使用 EXISTS 而第二個(gè)查詢使用 IN。注意兩個(gè)查詢返回相同的信息。

SELECT DISTINCT pub_nameFROM publishersWHERE EXISTS  (SELECT *  FROM titles  WHERE pub_id = publishers.pub_id  AND type = 'business')

 比較使用 EXISTS 和 = ANY 的查詢

本示例顯示查找與出版商住在同一城市中的作者的兩種查詢方法:第一種方法使用 = ANY,第二種方法使用 EXISTS。注意這兩種方法返回相同的信息。

SELECT au_lname, au_fnameFROM authorsWHERE exists  (SELECT *  FROM publishers  WHERE authors.city = publishers.city) 

比較使用 EXISTS 和 IN 的查詢

本示例所示查詢查找由位于以字母 B 開頭的城市中的任一出版商出版的書名:

SELECT titleFROM titlesWHERE EXISTS  (SELECT *  FROM publishers  WHERE pub_id = titles.pub_id  AND city LIKE 'B%')

使用 NOT EXISTS

NOT EXISTS 的作用與 EXISTS 正相反。如果子查詢沒有返回行,則滿足 NOT EXISTS 中的 WHERE 子句。本示例查找不出版商業(yè)書籍的出版商的名稱:

SELECT pub_nameFROM publishersWHERE NOT EXISTS  (SELECT *  FROM titles  WHERE pub_id = publishers.pub_id  AND type = 'business')ORDER BY pub_name

又比如以下 SQL 語(yǔ)句:

select distinct 姓名 from xswhere not exists (select * from kcwhere not exists (select * from xs_kcwhere 學(xué)號(hào)=xs.學(xué)號(hào) and 課程號(hào)=kc.課程號(hào))

把最外層的查詢xs里的數(shù)據(jù)一行一行的做里層的子查詢。

中間的 exists 語(yǔ)句只做出對(duì)上一層的返回 true 或 false,因?yàn)椴樵兊臈l件都在 where 學(xué)號(hào)=xs.學(xué)號(hào) and 課程號(hào)=kc.課程號(hào)這句話里。每一個(gè) exists 都會(huì)有一行值。它只是告訴一層,最外層的查詢條件在這里成立或都不成立,返回的時(shí)候值也一樣回返回上去。直到最高層的時(shí)候如果是 true(真)就返回到結(jié)果集。為 false(假)丟棄。

where not existsselect * from xs_kcwhere 學(xué)號(hào)=xs.學(xué)號(hào) and 課程號(hào)=kc.課程號(hào)

這個(gè) exists 就是告訴上一層,這一行語(yǔ)句在我這里不成立。因?yàn)樗皇亲罡邔樱赃€要繼續(xù)向上返回。

select distinct 姓名 from xs where not exists (這里的 exists 語(yǔ)句收到上一個(gè)為 false 的值。他在判斷一下,結(jié)果就是為 true(成立),由于是最高層所以就會(huì)把這行的結(jié)果(這里指的是查詢條件)返回到結(jié)果集。

幾個(gè)重要的點(diǎn):

  • 最里層要用到的醒詢條件的表比如:xs.學(xué)號(hào)、kc.課程號(hào)等都要在前面的時(shí)候說明一下select * from kc,select distinct 姓名 from xs
  • 不要在太注意中間的exists語(yǔ)句.
  • 把exists和not exists嵌套時(shí)的返回值弄明白

 

感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MYSQL教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 吴江市| 大英县| 盐山县| 交口县| 昌都县| 泰宁县| 中卫市| 阜平县| 垦利县| 巩留县| 丽江市| 夏津县| 西昌市| 鹿邑县| 徐州市| 营山县| 阜康市| 贞丰县| 安国市| 永福县| 边坝县| 红河县| 社会| 海丰县| 乐都县| 武宁县| 桐乡市| 宜阳县| 新泰市| 保康县| 雷波县| 南宁市| 洛川县| 兴业县| 新化县| 大洼县| 凉山| 三台县| 肇庆市| 大冶市| 桂林市|