国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Mysql exists用法小結(jié)

瀏覽:6日期:2023-10-07 18:43:18
簡(jiǎn)介

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

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

示例

一張活動(dòng)配置主表activity_main,通過act_code來唯一標(biāo)明一場(chǎng)活動(dòng),活動(dòng)舉辦地點(diǎn)適配表activity_area,通過act_code與主表進(jìn)行關(guān)聯(lián),活動(dòng)獎(jiǎng)品表activity_sku,通過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)名稱’,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 的查詢這個(gè)例子比較了兩個(gè)語義類似的查詢。第一個(gè)查詢使用 IN 而第二個(gè)查詢使用 EXISTS。注意兩個(gè)查詢返回相同的信息。

# 查詢體重秤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英國(guó)嬰兒推車select * from activity_main where act_code in (select act_code from activity_sku where sku like ’%B-BEKO%’)# 模糊查詢B-BEKO英國(guó)嬰兒推車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%’)# 查詢?cè)诓┛蛨@舉辦的活動(dòng)select * from activity_main where act_code in (select act_code from activity_area where area = ’博客園’)# 查詢?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語句只在當(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用法的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
相關(guān)文章:
主站蜘蛛池模板: 济源市| 诸城市| 肇州县| 安阳县| 岐山县| 伊川县| 长兴县| 上蔡县| 西畴县| 定边县| 大余县| 喀什市| 米泉市| 西乌珠穆沁旗| 卫辉市| 中江县| 青阳县| 穆棱市| 内江市| 宝山区| 罗定市| 岱山县| 尼木县| 鄂尔多斯市| 奉化市| 当雄县| 洪洞县| 淮阳县| 上蔡县| 习水县| 华亭县| 宁城县| 林甸县| 疏附县| 富平县| 阿克苏市| 蒲城县| 金堂县| 黎川县| 葵青区| 昌吉市|