当前位置:网站首页 > 数据科学与大数据 > 正文

数据库增删改查关键字(数据库增删改查的四个关键字)



MyBatis框架中的exists用法

  • exists用法
  • 使用示例
  • 总结


exists用法

  • exists:如果括号内子查询语句返回结果不为空,说明where条件成立,就会执行主SQL语句如果括号内子查询语句返回结果为空,说明where条件不成立,就不会执行主SQL语句
  • not exists: 与exists相反如果括号内子查询语句结果为空,说明表示where条件成立,就会执行主SQL语句如果括号内子查询语句结果不为空,说明表示where条件不成立,就不会执行主SQL语句exists与in的区别:in只能返回一个字段值exists强调是否返回结果集,不要求知道返回什么,exists允许返回多个字段exists的效率一般优于in:使用exists,Oracle首先会检查主查询,然后运行子查询直到找到第一个匹配项使用in子查询时,首先会执行子查询,并将获得的结果列表放在一个加了索引的临时表中exists的效率优于distinct:当提交一对多表信息查询时,就可以避免在select中使用distinct因为RDBMS核心模块将在子查询的条件一旦满足后,立即返回结果,所以自带去重.以下两组SQL语句等价:SELECT distinct dept_no, dept_name from dept D, EMP E WHERED.dept_no = E.dept_no; SELECT dept_no, dept_name from dept D WHERE EXISTS (SELECT 1 from emp E WHERE E·dept_no = D·dept_no);exists适合外表的结果极小的情况in适合内外表都很大的情况


使用示例

  • exists:

SELECT ID,NAME FROM A WHERE EXISTS(SELECT * FROM B WHERE A·ID = B·AID)

  • SQL语句分解:

SELECT ID,NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B·AID=1) --->SELECT * FROM B WHERE B.AID=1有值返回TRUE所以有数据 SELECT ID,NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B·AID=2) --->SELECT * FROM B WHERE B.AID=2有值返回TRUE所以有数据 SELECT ID,NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B·AID=3) --->SELECT * FROM B WHERE B.AID=3无值返回TRUE所以没有数据

  • 上面SQL语句等价于:

SELECT id, name from A WHERE id in (select aid from B)

总结

  • SQL中in, not in, exists, not exists的区别:in:确定给定的值是否与子查询或者列表中的值匹配in关键字选择与列表中任意一个值匹配的行in关键字之后的项目必须用逗号隔开,并且括在括号中not in:通过not in关键字引入的子查询也返回一列零值或更多值exists:指定一个子查询,检测行的存在相当于两个集合的交集exists后面可以是整句的查询语句 ,in后面只能是单列查询语句not exists:相当于两个集合的差集existsnot exists返回的结果类型是Boolean:如果子查询包含:exists返回TRUEnot exists返回FALSE


到此这篇数据库增删改查关键字(数据库增删改查的四个关键字)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • 数据库视频课程(数据库视频课程怎么下载)2025-11-29 10:36:04
  • 大数据培训(大数据培训和不培训的区别)2025-11-29 10:36:04
  • 数据库的端口是用来干什么的(数据库的端口号是什么意思)2025-11-29 10:36:04
  • 自动驾驶数据标注员有前途吗工资多少(自动驾驶数据标注工作内容)2025-11-29 10:36:04
  • mongodb数据库安装教程(mongodb安装使用)2025-11-29 10:36:04
  • 小米手机数据迁移(vivo手机换成小米手机数据迁移)2025-11-29 10:36:04
  • mongodb数据库是关系型(mongodb是不是关系型数据库)2025-11-29 10:36:04
  • 常用的中文期刊全文数据库(中文期刊全文数据库cnki)2025-11-29 10:36:04
  • 华为手机定位打开了无法获取位置(华为手机定位无法获取数据)2025-11-29 10:36:04
  • druid数据库连接池官网(druid连接池连接oracle)2025-11-29 10:36:04
  • 全屏图片