目录
- 一、exists
- 1.1 说明
- 1.2 示例
- 1.3 intersect/2017-07-21
- 二、except
- 2.1 说明
- 2.2 示例
- 三、测试数据
一、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 示例
--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 说明
查询结果上 except = not exists,intersect = exists,但是 except/intersect 的「查询开销」会比 not exists/exists 大很多。
except 自动去重复,not in/not exists不会。
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
三、测试数据
其中验证 except 去重复功能时在 family_member 中新增一个 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
到此这篇关于sqlserver中exists和except用法介绍的文章就介绍到这了,更多相关sqlserver中exists和except内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!