主頁(yè) > 知識(shí)庫(kù) > Mysql exists用法小結(jié)

Mysql exists用法小結(jié)

熱門(mén)標(biāo)簽:福州呼叫中心外呼系統(tǒng)哪家好 北京人工外呼系統(tǒng)價(jià)錢(qián) 沃克斯電梯外呼線(xiàn)路圖 房產(chǎn)智能外呼系統(tǒng)品牌 常州電銷(xiāo)外呼系統(tǒng)一般多少錢(qián) 400電話(huà)鄭州申請(qǐng) 天智外呼系統(tǒng) 地圖標(biāo)注被騙三百怎么辦 云南語(yǔ)音外呼系統(tǒng)平臺(tái)

簡(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)文章!

您可能感興趣的文章:
  • MySQL中in與exists的使用及區(qū)別介紹
  • 對(duì)比分析MySQL語(yǔ)句中的IN 和Exists
  • mysql exists與not exists實(shí)例詳解
  • MySQL exists 和in 詳解及區(qū)別
  • mySQL中in查詢(xún)與exists查詢(xún)的區(qū)別小結(jié)
  • MySQL關(guān)于exists的一個(gè)bug
  • 安裝mysql出錯(cuò)”A Windows service with the name MySQL already exists.“如何解決
  • MySQL的子查詢(xún)中FROM和EXISTS子句的使用教程
  • MYSQL IN 與 EXISTS 的優(yōu)化示例介紹
  • mysql not in、left join、IS NULL、NOT EXISTS 效率問(wèn)題記錄
  • UCenter info: MySQL Query Error SQL:SELECT value FROM [Table]vars WHERE noteexists

標(biāo)簽:徐州 沈陽(yáng) 珠海 黔東 移動(dòng) 鹽城 拉薩 沈陽(yáng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Mysql exists用法小結(jié)》,本文關(guān)鍵詞  Mysql,exists,用法,小結(jié),Mysql,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Mysql exists用法小結(jié)》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于Mysql exists用法小結(jié)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章