欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql?exists用法小結(jié)

 更新時間:2022年12月24日 12:33:45   作者:翎野君  
這篇文章主要介紹了Mysql?exists用法的的相關(guān)資料,幫助大家更好的理解和使用MySQL,感興趣的朋友可以了解下

簡介

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

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

在mysql中,exists用于檢查子查詢是否至少會返回一行數(shù)據(jù),該子查詢實際上并不返回任何數(shù)據(jù),而是返回true或false,語法為“SELECT 字段 FROM table WHERE EXISTS (subquery);”。

語法:

SELECT 字段 FROM table WHERE EXISTS (subquery);

參數(shù):

subquery是一個受限的SELECT語句(不允許有COMPUTE子句和INTO關(guān)鍵字)

示例:

SELECT * FROM A WHERE EXISTS (SELECT 1 FROM B WHERE B.id = A.id);

EXISTS執(zhí)行順序:

1、首先執(zhí)行一次外部查詢,并緩存結(jié)果集,如 SELECT * FROM A

2、遍歷外部查詢結(jié)果集的每一行記錄R,代入子查詢中作為條件進(jìn)行查詢,如 SELECT 1 FROM B WHERE B.id = A.id

3、如果子查詢有返回結(jié)果,則EXISTS子句返回TRUE,這一行R可作為外部查詢的結(jié)果行,否則不能作為結(jié)果

示例如下:

假設(shè)現(xiàn)在有三張表:

student:學(xué)生表,其中有字段sno為學(xué)號,sname為學(xué)生姓名

course:課程表,其中有字段cno為課程號,cname為課程名稱

student_course_relation:選課表,記錄學(xué)生選擇了哪些課程,其中有字段sno為學(xué)號,cno為課程號

下面通過幾個示例來說明一下EXISTS和NOT EXISTS的用法,及其與IN和NOT IN的區(qū)別

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

下面三種情況返回數(shù)據(jù)相同,都會返回student表的所有數(shù)據(jù):

select * from student;?
select * from student where exists (select 1);?
select * from student where exists (select null);

2、EXISTS子查詢返回的是一個布爾值true或false

EXISTS用于檢查子查詢是否至少會返回一行數(shù)據(jù),該子查詢實際上并不返回任何數(shù)據(jù),而是返回布爾值true或false,EXISTS指定一個子查詢,檢測行的存在。

EXISTS只在乎子查詢中是否有記錄,與具體的結(jié)果集無關(guān),所以下面示例中,子查詢中的select sno也可以換成select cno或者select 1,查詢出的結(jié)果集是一樣的。

查詢所有選修了課程號為3的學(xué)生:

select * from student a?
where exists (select sno from student_course_relation b where b.cno=3 and b.sno=a.sno);?
select * from student a?
where exists (select cno from student_course_relation b where b.cno=3 and b.sno=a.sno);?
select * from student a?
where exists (select 1 from student_course_relation b where b.cno=3 and b.sno=a.sno);

補充示例

一張活動配置主表activity_main,通過act_code來唯一標(biāo)明一場活動,活動舉辦地點適配表activity_area,通過act_code與主表進(jìn)行關(guān)聯(lián),活動獎品表activity_sku,通過act_code與主表進(jìn)行關(guān)聯(lián)。

活動主表

CREATE TABLE `activity_main` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`act_code` varchar(255) NOT NULL COMMENT '活動代碼',
`act_name` varchar(255) NOT NULL COMMENT '活動名稱',
PRIMARY KEY (`id`),
UNIQUE KEY `uniq_code` (`act_code`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='活動主表'

活動在哪些網(wǎng)站舉辦的適配表

CREATE TABLE `activity_area` (
 `id` bigint(20) NOT NULL AUTO_INCREMENT,
 `act_code` varchar(255) NOT NULL COMMENT '活動代碼',
 `area` varchar(255) NOT NULL COMMENT '參與此活動的網(wǎng)站',
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='活動適配的網(wǎng)站列表'

活動獎品表

CREATE TABLE `activity_sku` (
 `id` bigint(20) NOT NULL AUTO_INCREMENT,
 `act_code` varchar(255) NOT NULL COMMENT '活動代碼',
 `sku` varchar(255) NOT NULL COMMENT '活動贈送的商品',
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='活動贈品表'

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

# 查詢體重秤
select * from activity_main where act_code in (
select act_code from activity_sku where sku = '翎野君的體脂稱'
)

# 查詢體重秤
select * from activity_main a where exists (
select 1 from activity_sku b where a.act_code = b.act_code and b.sku = '翎野君的體脂稱'
)

# 模糊查詢B-BEKO英國嬰兒推車
select * from activity_main where act_code in (
select act_code from activity_sku where sku like '%B-BEKO%'
)

# 模糊查詢B-BEKO英國嬰兒推車
select * from activity_main a where exists (
select 1 from activity_sku b where a.act_code = b.act_code and b.sku like '%B-BEKO%'
)

# 查詢在博客園舉辦的活動
select * from activity_main where act_code in (
select act_code from activity_area where area = '博客園'
)

# 查詢在博客園舉辦的活動
select * from activity_main a where exists (
select 1 from activity_area b where a.act_code = b.act_code and b.area = '博客園'
)


# 在博客園舉辦活動且活動獎品為華為手機的活動信息
select * from activity_main where act_code in (
select act_code from activity_area where area = '博客園' and act_code in (
select act_code from activity_sku where sku = '華為P30Pro'
))


# 內(nèi)層的exists語句只在當(dāng)前where語句中生效,最終是否返回,要根據(jù)最外層的exists判斷,如果是 true(真)就返回到結(jié)果集,為 false(假)丟棄。
select * from activity_main a where exists (
select 1 from activity_area b where a.act_code = b.act_code and b.area = '博客園' and exists
(select 1 from activity_sku c where a.act_code = c.act_code and c.sku = '華為P30Pro')
)

以上就是Mysql exists用法小結(jié)的詳細(xì)內(nèi)容,更多關(guān)于Mysql exists用法的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 詳解MySQL用事件調(diào)度器Event Scheduler創(chuàng)建定時任務(wù)

    詳解MySQL用事件調(diào)度器Event Scheduler創(chuàng)建定時任務(wù)

    事件調(diào)度器(Event Scheduler)是在MySQLv5.1.6中新增的一個功能,它相當(dāng)于一個定時器,可以在指定的時間點執(zhí)行一條SQL語句或一個語句塊,也可以用于在固定間隔重復(fù)執(zhí)行。下面跟著小編一起來學(xué)習(xí)學(xué)習(xí)在MySQL中如何用事件調(diào)度器Event Scheduler創(chuàng)建定時任務(wù)
    2016-08-08
  • Mysql插入數(shù)據(jù)方式(insert into 、replace into解析)

    Mysql插入數(shù)據(jù)方式(insert into 、replace into解析)

    這篇文章主要介紹了Mysql插入數(shù)據(jù)方式(insert into 、replace into解析),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • sql查詢語句教程之插入、更新和刪除數(shù)據(jù)實例

    sql查詢語句教程之插入、更新和刪除數(shù)據(jù)實例

    如果要在程序運行過程中操作數(shù)據(jù)庫中的數(shù)據(jù),那得先學(xué)會使用SQL語句,下面這篇文章主要給大家介紹了關(guān)于sql查詢語句教程之插入、更新和刪除數(shù)據(jù)的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • Mysql中的Innodb事務(wù)和鎖詳解

    Mysql中的Innodb事務(wù)和鎖詳解

    這篇文章主要介紹了Mysql中的Innodb事務(wù)和鎖詳解,InnoDB是MySQL的一種存儲引擎,它是一種可靠性和性能非常好的存儲引擎,它具有ACID事務(wù)支持,可以提供高并發(fā)性和數(shù)據(jù)完整性,需要的朋友可以參考下
    2023-09-09
  • win10下mysql 8.0.11壓縮版安裝詳細(xì)教程

    win10下mysql 8.0.11壓縮版安裝詳細(xì)教程

    這篇文章主要為大家詳細(xì)介紹了win10下mysql 8.0.11壓縮版安裝詳細(xì)教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • MySQL中Like模糊查詢速度太慢該如何進(jìn)行優(yōu)化

    MySQL中Like模糊查詢速度太慢該如何進(jìn)行優(yōu)化

    在業(yè)務(wù)場景中經(jīng)常會用到like模糊查詢,但是大家都知道,like是用不到索引的,所以當(dāng)數(shù)據(jù)量非常大時,速度會非常慢,這篇文章主要給大家介紹了關(guān)于MySQL中Like模糊查詢速度太慢該如何進(jìn)行優(yōu)化的相關(guān)資料,需要的朋友可以參考下
    2021-12-12
  • mysql數(shù)據(jù)庫表的多條件查詢語句

    mysql數(shù)據(jù)庫表的多條件查詢語句

    這篇文章主要介紹了mysql數(shù)據(jù)庫表的多條件查詢語句,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06
  • Mysql 5.6

    Mysql 5.6 "隱式轉(zhuǎn)換"導(dǎo)致的索引失效和數(shù)據(jù)不準(zhǔn)確的問題

    這篇文章主要介紹了Mysql 5.6 “隱式轉(zhuǎn)換”導(dǎo)致的索引失效和數(shù)據(jù)不準(zhǔn)確的問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • 如何實現(xiàn)mysql的遠(yuǎn)程連接

    如何實現(xiàn)mysql的遠(yuǎn)程連接

    這篇文章詳細(xì)介紹了mysql如何實現(xiàn)遠(yuǎn)程連接,文中有詳細(xì)的代碼實例講解,有一定的參考價值,需要的朋友可以參考閱讀
    2023-04-04
  • MySQL的日志基礎(chǔ)知識及基本操作學(xué)習(xí)教程

    MySQL的日志基礎(chǔ)知識及基本操作學(xué)習(xí)教程

    這篇文章主要介紹了MySQL的日志基礎(chǔ)知識學(xué)習(xí)教程,包括MySQL中日志相關(guān)常用的服務(wù)器變量說明,極力推薦!需要的朋友可以參考下
    2015-11-11

最新評論