SQLServer中exists和except用法介紹
一、exists
1.1 說明
EXISTS(包括 NOT EXISTS)子句的返回值是一個(gè) BOOL 值。EXISTS 內(nèi)部有一個(gè)子查詢語(yǔ)句(SELECT ... FROM...),我將其稱為 EXIST 的內(nèi)查詢語(yǔ)句。其內(nèi)查詢語(yǔ)句返回一個(gè)結(jié)果集。
EXISTS 子句根據(jù)其內(nèi)查詢語(yǔ)句的結(jié)果集空或者非空,返回一個(gè)布爾值。
exists:強(qiáng)調(diào)的是是否返回結(jié)果集,不要求知道返回什么,比如:select name from student where sex = 'm' and mark exists(select 1 from grade where ...)
,只要 exists 引導(dǎo)的子句有結(jié)果集返回,那么 exists 這個(gè)條件就算成立了,大家注意返回的字段始終為 1,如果改成 select 2 from grade where ...
,那么返回的字段就是 2,這個(gè)數(shù)字沒有意義。所以 exists 子句不在乎返回什么,而是在乎是不是有結(jié)果集返回。EXISTS = IN,意思相同不過語(yǔ)法上有點(diǎn)點(diǎn)區(qū)別,好像使用 IN 效率要差點(diǎn),應(yīng)該是不會(huì)執(zhí)行索引的原因。
相對(duì)于 inner join,exists 性能要好一些,當(dāng)它找到第一個(gè)符合條件的記錄時(shí),就會(huì)立即停止搜索返回 TRUE。
1.2 示例
--EXISTS --SQL: select name from family_member where group_level > 0 and exists(select 1 from family_grade where family_member.name = family_grade.name and grade > 90) --result: name cherrie --NOT EXISTS --SQL: select name from family_member where group_level > 0 and not exists(select 1 from family_grade where family_member.name = family_grade.name and grade > 90) --result: name mazey rabbit
1.3 intersect/2017-07-21
intersect 的作用與 exists 類似。
--intersect --SQL: select name from family_member where group_level > 0 intersect select name from family_grade where grade > 90 --result: name cherrie
二、except
2.1 說明
查詢結(jié)果上 EXCEPT = NOT EXISTS,INTERSECT = EXISTS,但是 EXCEPT/INTERSECT 的「查詢開銷」會(huì)比 NOT EXISTS/EXISTS 大很多。
except 自動(dòng)去重復(fù),not in/not exists不會(huì)。
2.2 示例
--except --SQL: select name from family_member where group_level > 0 except(select name from family_grade) --result: name rabbit --NOT EXISTS --SQL: select name from family_member where group_level > 0 and not exists(select name from family_grade where family_member.name = family_grade.name) --result: name rabbit rabbit
三、測(cè)試數(shù)據(jù)
其中驗(yàn)證 except 去重復(fù)功能時(shí)在 family_member 中新增一個(gè) rabbit。
-- ---------------------------- -- Table structure for family_grade -- ---------------------------- DROP TABLE [mazeytop].[family_grade] GO CREATE TABLE [mazeytop].[family_grade] ( [id] int NOT NULL , [name] varchar(20) NULL , [grade] int NULL ) GO -- ---------------------------- -- Records of family_grade -- ---------------------------- INSERT INTO [mazeytop].[family_grade] ([id], [name], [grade]) VALUES (N'1', N'mazey', N'70') GO GO INSERT INTO [mazeytop].[family_grade] ([id], [name], [grade]) VALUES (N'2', N'cherrie', N'93') GO GO -- ---------------------------- -- Table structure for family_member -- ---------------------------- DROP TABLE [mazeytop].[family_member] GO CREATE TABLE [mazeytop].[family_member] ( [id] int NOT NULL , [name] varchar(20) NULL , [sex] varchar(20) NULL , [age] int NULL , [group_level] int NULL ) GO -- ---------------------------- -- Records of family_member -- ---------------------------- INSERT INTO [mazeytop].[family_member] ([id], [name], [sex], [age], [group_level]) VALUES (N'1', N'mazey', N'male', N'23', N'1') GO GO INSERT INTO [mazeytop].[family_member] ([id], [name], [sex], [age], [group_level]) VALUES (N'2', N'cherrie', N'female', N'22', N'2') GO GO INSERT INTO [mazeytop].[family_member] ([id], [name], [sex], [age], [group_level]) VALUES (N'3', N'rabbit', N'female', N'15', N'3') GO GO INSERT INTO [mazeytop].[family_member] ([id], [name], [sex], [age], [group_level]) VALUES (N'4', N'rabbit', N'female', N'15', N'3') GO GO -- ---------------------------- -- Table structure for family_part -- ---------------------------- DROP TABLE [mazeytop].[family_part] GO CREATE TABLE [mazeytop].[family_part] ( [id] int NOT NULL , [group] int NULL , [group_name] varchar(20) NULL ) GO -- ---------------------------- -- Records of family_part -- ---------------------------- INSERT INTO [mazeytop].[family_part] ([id], [group], [group_name]) VALUES (N'1', N'1', N'父親') GO GO INSERT INTO [mazeytop].[family_part] ([id], [group], [group_name]) VALUES (N'2', N'2', N'母親') GO GO INSERT INTO [mazeytop].[family_part] ([id], [group], [group_name]) VALUES (N'3', N'3', N'女兒') GO GO -- ---------------------------- -- Indexes structure for table family_grade -- ---------------------------- -- ---------------------------- -- Primary Key structure for table family_grade -- ---------------------------- ALTER TABLE [mazeytop].[family_grade] ADD PRIMARY KEY ([id]) GO -- ---------------------------- -- Indexes structure for table family_member -- ---------------------------- -- ---------------------------- -- Primary Key structure for table family_member -- ---------------------------- ALTER TABLE [mazeytop].[family_member] ADD PRIMARY KEY ([id]) GO -- ---------------------------- -- Indexes structure for table family_part -- ---------------------------- -- ---------------------------- -- Primary Key structure for table family_part -- ---------------------------- ALTER TABLE [mazeytop].[family_part] ADD PRIMARY KEY ([id]) GO
到此這篇關(guān)于SQLServer中exists和except用法介紹的文章就介紹到這了,更多相關(guān)SQLServer中exists和except內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
利用DataSet部分功能實(shí)現(xiàn)網(wǎng)站登錄
這篇文章主要介紹了利用DataSet部分功能實(shí)現(xiàn)網(wǎng)站登錄 ,需要的朋友可以參考下2017-05-05在數(shù)據(jù)庫(kù)中如何高效的實(shí)現(xiàn)訂座功能
這篇文章主要給大家介紹了關(guān)于在數(shù)據(jù)庫(kù)中如何高效的實(shí)現(xiàn)訂座功能的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11使用Sqlyog遠(yuǎn)程連接數(shù)據(jù)庫(kù)報(bào)錯(cuò)解決方案
大家好,本篇文章主要講的是使用Sqlyog遠(yuǎn)程連接數(shù)據(jù)庫(kù)報(bào)錯(cuò)解決方案,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12sql2005可實(shí)時(shí)監(jiān)測(cè)數(shù)據(jù)庫(kù)版本控制SQL的觸發(fā)器
用于sql2005實(shí)時(shí)監(jiān)測(cè)數(shù)據(jù)庫(kù)版本控制SQL的觸發(fā)器2008-10-10使用Navicat生成ER關(guān)系圖并導(dǎo)出的方法
這篇文章主要介紹了使用Navicat生成ER關(guān)系圖并導(dǎo)出的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11執(zhí)行Insert Exec時(shí)的隱藏開銷 分析
Insert Exec時(shí)的隱藏開銷,大家可以參考下。2009-07-07