我的编程空间,编程开发者的网络收藏夹
学习永远不晚

SQLServer中exists和except怎么使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

SQLServer中exists和except怎么使用

这篇文章主要介绍“SQLServer中exists和except怎么使用”,在日常操作中,相信很多人在SQLServer中exists和except怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”SQLServer中exists和except怎么使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

    一、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_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

    1.3 intersect/2017-07-21

    intersect 的作用与 exists 类似。

    --intersect--SQL:select name from family_member where group_level > 0intersectselect name from family_grade where grade > 90--result:namecherrie

    二、except

    2.1 说明

    查询结果上 EXCEPT = NOT EXISTS,INTERSECT = EXISTS,但是 EXCEPT/INTERSECT 的「查询开销」会比 NOT EXISTS/EXISTS 大很多。

    except 自动去重复,not in/not exists不会。

    SQLServer中exists和except怎么使用

    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

    三、测试数据

    其中验证 except 去重复功能时在 family_member 中新增一个 rabbit。

    -- ------------------------------ 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怎么使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    SQLServer中exists和except怎么使用

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    SQLServer中exists和except怎么使用

    这篇文章主要介绍“SQLServer中exists和except怎么使用”,在日常操作中,相信很多人在SQLServer中exists和except怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”SQL
    2023-06-21

    sql中exists和not exists怎么使用

    在SQL中,EXISTS和NOT EXISTS是用来检查子查询是否返回结果的条件表达式。- EXISTS:如果子查询返回至少一行结果,则返回true,否则返回false。例如:```sqlSELECT * FROM table1 WHERE
    2023-08-16

    SqlServer中Exists的使用小结

    SQLServer中Exists操作符:Exists检查子查询结果集是否存在行,返回布尔值。语法:SELECT*FROMtableWHEREEXISTS(SELECT1FROMtable2WHEREtable2.column=table1.column)。优点:提高性能语法简洁灵活性用途:检查数据是否存在验证约束执行复杂查询局限性:不返回具体值可能导致额外开销最佳实践:考虑性能影响简化子查询使用索引避免不必要的嵌套微调查询
    SqlServer中Exists的使用小结
    2024-04-02

    sql中exists和not exists怎么用

    这篇文章主要介绍了sql中exists和not exists怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。exists:强调的是是否有返回集,不需知道具体返回的是什么,
    2023-06-29

    sql中exists怎么使用

    在SQL中,EXISTS是一个用于检查子查询结果是否存在的操作符。它返回一个布尔值,表示是否存在。以下是EXISTS的使用方法:1. 使用EXISTS条件:```sqlSELECT column1, column2, ...FROM tab
    2023-08-08

    mysql中exists怎么使用

    在MySQL中,`EXISTS`是一个用于判断子查询中是否存在数据的关键字。它的使用方式如下:```sqlSELECT column_name(s)FROM table_nameWHERE EXISTS (subquery);```在`WH
    2023-08-29

    python中try-except-finally语句怎么使用

    本文小编为大家详细介绍“python中try-except-finally语句怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“python中try-except-finally语句怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路
    2023-06-30

    使用SQL中的EXISTS和NOT EXISTS的语法

    SQL中的exists和not exists的用法,需要具体的代码示例在SQL中,exists和not exists是一对常用的谓词(predicate),用于判断一个子查询(subquery)是否返回了结果集。exists用于检查子查询
    使用SQL中的EXISTS和NOT EXISTS的语法
    2024-02-22

    sql中not exists怎么使用

    在SQL中,NOT EXISTS 是一个条件运算符,用于检查子查询的结果是否为空。它用于在主查询中过滤掉那些在子查询中存在的记录。使用 NOT EXISTS,你需要编写一个子查询,并在主查询中使用该条件运算符来检查子查询的结果。子查询可以是
    2023-08-08

    try-except-finally语句怎么在python中使用

    这期内容当中小编将会给大家带来有关try-except-finally语句怎么在python中使用,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Python的优点有哪些1、简单易用,与C/C++、Java
    2023-06-14

    oracle中的not exists怎么使用

    在Oracle中,NOT EXISTS是一个用于查询的条件表达式,用于检查一个子查询是否为空。如果子查询返回的结果集为空,则NOT EXISTS条件返回TRUE,否则返回FALSE。NOT EXISTS的语法如下:```SELECT col
    2023-08-23

    Python中怎么避免滥用try...except

    这篇文章主要讲解了“Python中怎么避免滥用try...except”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python中怎么避免滥用try...except”吧!有不少人在写 Py
    2023-06-16

    mysql中关键词exists怎么使用

    这篇文章主要讲解了“mysql中关键词exists怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql中关键词exists怎么使用”吧!语法解释语法SELECT column1
    2023-07-02

    mysql中的关键词exists怎么使用

    在MySQL中,EXISTS 关键字用于检查子查询是否返回任何行。它的语法如下:SELECT column1, column2, ...FROM table_nameWHERE EXISTS (subquery);例如,假设我们有两个
    mysql中的关键词exists怎么使用
    2024-04-09

    怎么在python中使用except对异常进行处理

    本篇文章为大家展示了怎么在python中使用except对异常进行处理,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。python有哪些常用库python常用的库:1.requesuts;2.scra
    2023-06-14

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录