Mysql exists用法小結
EXISTS用于檢查子查詢是否至少會返回一行數(shù)據(jù),該子查詢實際上并不返回任何數(shù)據(jù),而是返回值True或False。
EXISTS 指定一個子查詢,檢測行的存在。語法:EXISTS subquery。參數(shù) subquery 是一個受限的 SELECT 語句 (不允許有 COMPUTE 子句和 INTO 關鍵字)。結果類型為 Boolean,如果子查詢包含行,則返回 TRUE。
示例一張活動配置主表activity_main,通過act_code來唯一標明一場活動,活動舉辦地點適配表activity_area,通過act_code與主表進行關聯(lián),活動獎品表activity_sku,通過act_code與主表進行關聯(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語句只在當前where語句中生效,最終是否返回,要根據(jù)最外層的exists判斷,如果是 true(真)就返回到結果集,為 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用法小結的詳細內(nèi)容,更多關于Mysql exists用法的資料請關注好吧啦網(wǎng)其它相關文章!
相關文章:
1. oracle數(shù)據(jù)庫去除重復數(shù)據(jù)常用的方法總結2. SQL Server一個字符串拆分多行顯示或者多行數(shù)據(jù)合并成一個字符串3. MySQL字符串拼接與分組拼接字符串實例代碼4. DB2 日期和時間的函數(shù)應用說明5. 用SQL語句查找Access中某表是否存在的小技巧6. Oracle表分區(qū)詳解7. SQL案例學習之字符串的合并與拆分方法總結8. access不能打開注冊表關鍵字錯誤處理方法(80004005錯誤)9. SQL Server使用CROSS APPLY與OUTER APPLY實現(xiàn)連接查詢10. MySQL之常用的MySQL優(yōu)化工具解讀
