激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫(kù)技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫(kù) - Sql Server - SQLServer中exists和except用法介紹

SQLServer中exists和except用法介紹

2022-01-17 18:07后除MZ Sql Server

大家好,本篇文章主要講的是SQLServer中exists和except用法介紹,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下哦

 

一、exists

 

1.1 說(shuō)明

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ù)字沒(méi)有意義。所以 exists 子句不在乎返回什么,而是在乎是不是有結(jié)果集返回。EXISTS = IN,意思相同不過(guò)語(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 示例

?
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 說(shuō)明

查詢結(jié)果上 EXCEPT = NOT EXISTS,INTERSECT = EXISTS,但是 EXCEPT/INTERSECT 的「查詢開(kāi)銷」會(huì)比 NOT EXISTS/EXISTS 大很多。

except 自動(dòng)去重復(fù),not in/not exists不會(huì)。

SQLServer中exists和except用法介紹

 

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

 

三、測(cè)試數(shù)據(jù)

其中驗(yàn)證 except 去重復(fù)功能時(shí)在 family_member 中新增一個(gè) 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

到此這篇關(guān)于SQLServer中exists和except用法介紹的文章就介紹到這了,更多相關(guān)SQLServer中exists和except內(nèi)容請(qǐng)搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!

原文鏈接:https://blog.51cto.com/mazey/4731892

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久久一区二区精品 | 日韩黄a| 九九热视频这里只有精品 | 国产乱淫av片免费 | 国产在线观看av | 综合精品视频 | 欧美城网站地址 | 国产一区二区精彩视频 | 免费放黄网站在线播放 | 久久久一区二区三区四区 | 中文字幕精品久久 | 二区三区四区视频 | 欧美成人精品欧美一级乱黄 | 久久久无码精品亚洲日韩按摩 | 国产精品美女一区二区 | a免费视频 | 中文字幕在线免费播放 | 久久草草亚洲蜜桃臀 | 性生活视频软件 | 欧美性精品videofree | 最近免费观看高清韩国日本大全 | 精品久久久久久中文字幕 | 国产伦乱视频 | 中国av免费在线观看 | av不卡毛片 | 国产亚洲综合一区二区 | 亚洲精久| 精品在线视频观看 | av电影在线观看网址 | 国产精品成人一区二区三区吃奶 | 精品国产乱码久久久久久丨区2区 | 成人国产精品一区 | 羞羞色在线观看 | 免费看欧美黑人毛片 | 中国黄色一级生活片 | 日本精品久久久一区二区三区 | 日韩视频中文 | 亚洲午夜精品视频 | 性高跟鞋xxxxhd4kvideos | 欧美在线国产 | 精品国产一区二区三区久久久蜜 |