Mysql exists用法小結(jié)
簡(jiǎn)介
EXISTS用于檢查子查詢(xún)是否至少會(huì)返回一行數(shù)據(jù),該子查詢(xún)實(shí)際上并不返回任何數(shù)據(jù),而是返回值True或False。
EXISTS 指定一個(gè)子查詢(xún),檢測(cè)行的存在。語(yǔ)法:EXISTS subquery。參數(shù) subquery 是一個(gè)受限的 SELECT 語(yǔ)句 (不允許有 COMPUTE 子句和 INTO 關(guān)鍵字)。結(jié)果類(lèi)型為 Boolean,如果子查詢(xún)包含行,則返回 TRUE。
示例
一張活動(dòng)配置主表activity_main,通過(guò)act_code來(lái)唯一標(biāo)明一場(chǎng)活動(dòng),活動(dòng)舉辦地點(diǎn)適配表activity_area,通過(guò)act_code與主表進(jìn)行關(guān)聯(lián),活動(dòng)獎(jiǎng)品表activity_sku,通過(guò)act_code與主表進(jìn)行關(guān)聯(lián)。
活動(dòng)主表
CREATE TABLE `activity_main` ( `id` bigint(20) NOT NULL AUTO_INCREMENT, `act_code` varchar(255) NOT NULL COMMENT '活動(dòng)代碼', `act_name` varchar(255) NOT NULL COMMENT '活動(dòng)名稱(chēng)', PRIMARY KEY (`id`), UNIQUE KEY `uniq_code` (`act_code`) ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='活動(dòng)主表'
活動(dòng)在哪些網(wǎng)站舉辦的適配表
CREATE TABLE `activity_area` ( `id` bigint(20) NOT NULL AUTO_INCREMENT, `act_code` varchar(255) NOT NULL COMMENT '活動(dòng)代碼', `area` varchar(255) NOT NULL COMMENT '參與此活動(dòng)的網(wǎng)站', PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='活動(dòng)適配的網(wǎng)站列表'
活動(dòng)獎(jiǎng)品表
CREATE TABLE `activity_sku` ( `id` bigint(20) NOT NULL AUTO_INCREMENT, `act_code` varchar(255) NOT NULL COMMENT '活動(dòng)代碼', `sku` varchar(255) NOT NULL COMMENT '活動(dòng)贈(zèng)送的商品', PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='活動(dòng)贈(zèng)品表'
比較使用 EXISTS 和 IN 的查詢(xún)
這個(gè)例子比較了兩個(gè)語(yǔ)義類(lèi)似的查詢(xún)。第一個(gè)查詢(xún)使用 IN 而第二個(gè)查詢(xún)使用 EXISTS。注意兩個(gè)查詢(xún)返回相同的信息。
# 查詢(xún)體重秤 select * from activity_main where act_code in ( select act_code from activity_sku where sku = '翎野君的體脂稱(chēng)' ) # 查詢(xún)體重秤 select * from activity_main a where exists ( select 1 from activity_sku b where a.act_code = b.act_code and b.sku = '翎野君的體脂稱(chēng)' ) # 模糊查詢(xún)B-BEKO英國(guó)嬰兒推車(chē) select * from activity_main where act_code in ( select act_code from activity_sku where sku like '%B-BEKO%' ) # 模糊查詢(xún)B-BEKO英國(guó)嬰兒推車(chē) 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%' ) # 查詢(xún)?cè)诓┛蛨@舉辦的活動(dòng) select * from activity_main where act_code in ( select act_code from activity_area where area = '博客園' ) # 查詢(xún)?cè)诓┛蛨@舉辦的活動(dòng) select * from activity_main a where exists ( select 1 from activity_area b where a.act_code = b.act_code and b.area = '博客園' ) # 在博客園舉辦活動(dòng)且活動(dòng)獎(jiǎng)品為華為手機(jī)的活動(dòng)信息 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語(yǔ)句只在當(dāng)前where語(yǔ)句中生效,最終是否返回,要根據(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用法的資料請(qǐng)關(guān)注本站其它相關(guān)文章!
版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。