標籤:sqlserver sql
一、exists1.1 說明
EXISTS(包括 NOT EXISTS)子句的傳回值是一個BOOL值。EXISTS內部有一個子查詢語句(SELECT ... FROM...),我將其稱為EXIST的內查詢語句。其內查詢語句返回一個結果集。EXISTS子句根據其內查詢語句的結果集空或者非空,返回一個布爾值。Link
exists:強調的是是否返回結果集,不要求知道返回什麼,比如:select name from student where sex = ‘m‘ and mark exists(select 1 from grade where ...) ,只要exists引導的子句有結果集返回,那麼exists這個條件就算成立了,大家注意返回的欄位始終為1,如果改成“select 2 from grade where ...”,那麼返回的欄位就是2,這個數字沒有意義。所以exists子句不在乎返回什麼,而是在乎是不是有結果集返回。EXISTS = IN,意思相同不過文法上有點點區別,好像使用IN效率要差點,應該是不會執行索引的原因。Link
相對於inner join,exists效能要好一些,當她找到第一個合格記錄時,就會立即停止搜尋返回TRUE。
1.2 樣本
--EXISTS--SQL:select name from family_memberwhere group_level > 0and exists(select 1 from family_grade where family_member.name = family_grade.nameand grade > 90)--result:namecherrie--NOT EXISTS--SQL:select name from family_memberwhere group_level > 0and not exists(select 1 from family_grade where family_member.name = family_grade.nameand grade > 90)--result:namemazeyrabbit
二、except2.1 說明
查詢結果上EXCEPT = NOT EXISTS,INTERSECT = EXISTS,但是EXCEPT / INTERSECT的「查詢開銷」會比NOT EXISTS / EXISTS大很多。
except自動去重複,not in / not exists不會。
2.2 樣本
--except--SQL:select name from family_memberwhere group_level > 0except(select name from family_grade)--result:namerabbit--NOT EXISTS--SQL:select name from family_memberwhere group_level > 0and not exists(select name from family_grade where family_member.name = family_grade.name)--result:namerabbitrabbit
三、測試資料
-- ------------------------------ Table structure for family_grade-- ----------------------------DROP TABLE [mazeytop].[family_grade]GOCREATE 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‘)GOGOINSERT INTO [mazeytop].[family_grade] ([id], [name], [grade]) VALUES (N‘2‘, N‘cherrie‘, N‘93‘)GOGO-- ------------------------------ Table structure for family_member-- ----------------------------DROP TABLE [mazeytop].[family_member]GOCREATE 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‘)GOGOINSERT INTO [mazeytop].[family_member] ([id], [name], [sex], [age], [group_level]) VALUES (N‘2‘, N‘cherrie‘, N‘female‘, N‘22‘, N‘2‘)GOGOINSERT INTO [mazeytop].[family_member] ([id], [name], [sex], [age], [group_level]) VALUES (N‘3‘, N‘rabbit‘, N‘female‘, N‘15‘, N‘3‘)GOGOINSERT INTO [mazeytop].[family_member] ([id], [name], [sex], [age], [group_level]) VALUES (N‘4‘, N‘rabbit‘, N‘female‘, N‘15‘, N‘3‘)GOGO-- ------------------------------ Table structure for family_part-- ----------------------------DROP TABLE [mazeytop].[family_part]GOCREATE 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‘父親‘)GOGOINSERT INTO [mazeytop].[family_part] ([id], [group], [group_name]) VALUES (N‘2‘, N‘2‘, N‘母親‘)GOGOINSERT INTO [mazeytop].[family_part] ([id], [group], [group_name]) VALUES (N‘3‘, N‘3‘, N‘女兒‘)GOGO-- ------------------------------ 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
SQLServer中exists和except用法
本文出自 “不知不問” 部落格,請務必保留此出處http://mazey.blog.51cto.com/12997993/1947482
SQLServer中exists和except用法