一、exists
1.1 說明
EXISTS(包括 NOT EXISTS)子句的返回值是一個 BOOL 值。EXISTS 內部有一個子查詢語句(SELECT ... FROM...),我將其稱為 EXIST 的內查詢語句。其內查詢語句返回一個結果集。
EXISTS 子句根據其內查詢語句的結果集空或者非空,返回一個布爾值。
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 效率要差點,應該是不會執行索引的原因。
相對于 inner join,exists 性能要好一些,當它找到第一個符合條件的記錄時,就會立即停止搜索返回 TRUE。
1.2 示例
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
--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 類似。
1
2
3
4
5
6
7
8
9
|
--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 說明
查詢結果上 EXCEPT = NOT EXISTS,INTERSECT = EXISTS,但是 EXCEPT/INTERSECT 的「查詢開銷」會比 NOT EXISTS/EXISTS 大很多。
except 自動去重復,not in/not exists不會。
2.2 示例
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
--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 |
三、測試數據
其中驗證 except 去重復功能時在 family_member 中新增一個 rabbit。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
-- ---------------------------- -- 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 |
到此這篇關于SQLServer中exists和except用法介紹的文章就介紹到這了,更多相關SQLServer中exists和except內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!
原文鏈接:https://blog.51cto.com/mazey/4731892