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

sql中exists的基本用法示例

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

sql中exists的基本用法示例

现有:班级表(A_CLASS)

sql中exists的基本用法示例

学生表( STUDENT)

sql中exists的基本用法示例

注:学生表(STUDENT)的classId关联班级表(A_CLASS)的主键ID

代码:

select * from STUDENT s WHERE exists (select 1 from A_ClASS c where s.CLASS_ID=c.ID)

结果

sql中exists的基本用法示例

【exists语句的执行顺序如下】:

1.首先会执行外循环(select * from student

2.外循环返回的结果每一行都会拿着去内层循环执行(此时注意,内层也是循环查询的)

ps:select * from student查询的为 (c1,c1,c2,c3);此时执行顺序应该是(

第一次:select* from A_CLASS where c1=c1,第二次:select* from A_CLASS where c1=c2,

第三次:select* from A_CLASS where c1=c1,第四次:select* from A_CLASS where c1=c2,

第五次:select* from A_CLASS where c2=c1,第六次:select* from A_CLASS where c2=c2,

第七次:select* from A_CLASS where c3=c1,第八次:select* from A_CLASS where c3=c2)

注意:此时的内层子查询如果为true,则直接返回不会再继续执行本次循环;

综上所述:第二次和第四次是不会被执行的;  第一次和第三次还有第六次是符合条件的;

所以 STUDENT表中CLASS_ID字段为(c1,c2)的数据都会被查询出来;

如果将 上述语句的=换成!=会是什么效果?

select * from STUDENT s WHERE exists (select 1 from A_ClASS c where s.CLASS_ID!=c.ID)

结果如果所示: 

sql中exists的基本用法示例

具体分析一下:此时的执行应该和第一次一模一样也是循环8次分别为:

第一次:select* from A_CLASS where c1!=c1,第二次:select* from A_CLASS where c1!=c2,

第三次:select* from A_CLASS where c1!=c1,第四次:select* from A_CLASS where c1!=c2,

第五次:select* from A_CLASS where c2!=c1,第六次:select* from A_CLASS where c2!=c2,

第七次:select* from A_CLASS where c3!=c1,第八次:select* from A_CLASS where c3!=c2

但是=换成了!=;这次是第六次和第八次没有被执行,其余的全被执行,s.CLASS_ID涉及到(c1,c2,c3)并且语句都返回了true;

所以STUDENT表中CLASS_ID字段为(c1,c2,c3)的数据都会被查询出来;

附:exists与in比较

in的用法相信大家很好理解。

select * from table_name where col_name [not] in(子查询);
  • 先运行子查询,生成结果集
  • 再运行外查询时,判断col_name在不在子查询里,在的话则返回该行,不在则不返回。
  • col_name的列数和子查询的列数要相对应

当外大子小时,即查询的内容很大时,判断次数少,in优于exist【子查询小用in】

当外小子大时,即查询内容很小时,代入次数少,exists优于in【子查询大用exists】

总结:

1.exists执行外循环后,会拿着外循环的值,去内层查询,如果查询到就直接返回true,并且终止本次循环,如果是false,则会一直执行,直至循环完成还为false,则本次内循环不符合条件;

2.内层的判断条件不要写!=;查询的结果会不尽人意;

到此这篇关于sql中exists基本用法的文章就介绍到这了,更多相关sql exists的用法内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

免责声明:

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

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

sql中exists的基本用法示例

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

下载Word文档

猜你喜欢

sql中exists的基本用法示例

目录【exists语句的执行顺序如下】:附:exists与in比较总结:现有:班级表(A_CLASS)学生表( STUDENT)注:学生表(STUDENT)的classId关联班级表(A_CLASS)的主键ID代码:select * f
2022-08-16

sql中exists的基本用法

EXISTS是SQL中用于判断一个子查询是否有返回结果的关键字,返回值为true或者false,表示子查询是否存在结果,基本语法为“SELECT column1, column2”,column1, column2, ... 是需要查询的列
sql中exists的基本用法
2024-01-29

sql中exists的基本用法是什么

在SQL中,EXISTS是一个用来检查子查询是否返回任何行的条件表达式。基本用法是在SELECT语句中使用EXISTS来检查子查询的结果是否存在,如果存在则返回TRUE,否则返回FALSE。示例:SELECT column1, colu
sql中exists的基本用法是什么
2024-04-09

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

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

Objective-C中NSArray的基本用法示例

NSArray的排序+ (id)studentWithFirstName:(NSString *)firstName lastName:(NSString *)lastName{ Student *stu = [[
2022-05-19

Echarts图表中formatter的基本用法示例

formatter提示框浮层内容格式器,支持字符串模板和回调函数两种形式,下面这篇文章主要给大家介绍了关于Echarts图表中formatter的基本用法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
2023-02-14

vue2和vue3中provide/inject的基本用法示例

Vue中的provide/inject是一种组件间通信的方式,它允许父组件向子组件传递数据,而不需要通过props或事件来实现,下面这篇文章主要给大家介绍了关于vue2/vue3中provide/inject的基本用法的相关资料,需要的朋友可以参考下
2023-05-17

Android DatePicker和DatePickerDialog基本用法示例

本文实例讲述了Android DatePicker和DatePickerDialog基本用法。分享给大家供大家参考,具体如下: DatePicker用来设置手机的时间和闹钟 1、添加一个按钮控件在配置文件中,然后给该按钮添加事件,使其能够打
2022-06-06

Android AutoCompleteTextView控件基本用法示例

本文实例讲述了Android AutoCompleteTextView控件基本用法。分享给大家供大家参考,具体如下: 当输入部分内容之后会有相关的建议,类似于百度提示信息 1、在布局文件中声明一个AutoCompleteTextView
2022-06-06

Android 通知的基本用法示例代码

写android通知的时候发现Notification的setLatestEventInfo被弃用,于是搜素并整理了一下新的android通知的基本用法。 一、获取NotificationManager实例NotificationManag
2022-06-06

编程热搜

目录