当前位置:   article > 正文

真正理解exists 和not exists_where not exists

where not exists

exists与not exists

原理解释:

exists(sql返回结果集为真)

not exists(sql不返回结果集为真或返回结果集为假)

这看的挺懵逼的,这里详细的解释下exists和not exists的原理和用法吧。

  1. select * from A where not exists(select * from B where A.id = B.id);
  2. select * from A where exists(select * from B where A.id = B.id);

 首先我们要知道sql语句使用了exists或not exists后的执行顺序,注意,是先执行外查询再执行内查询。这和我们学的子查询概念就“冲突了”,特别是刚学完子查询后再学exists,简直让人崩溃。


详细步骤(使用exists):

1,首先执行外查询select * from A,然后从外查询的数据取出一条数据传给内查询。

2,内查询执行select * from B,外查询传入的数据和内查询获得数据根据where后面的条件做匹对,如果存在数据满足A.id=B.id则返回true,如果一条都不满足则返回false。

3,内查询返回true,则外查询的这行数据保留,反之内查询返回false则外查询的这行数据不显示。外查询的所有数据逐行查询匹对。

not exists和exists的用法相反,就不继续啰嗦了。

案例分析
还是根据上面的那道题做分析来看看not exists或exists是如何用的吧。
 

  1. # 学生表
  2. CREATE TABLE `Student`(
  3. `s_id` VARCHAR(20),
  4. `s_name` VARCHAR(20) NOT NULL DEFAULT '',
  5. `s_birth` VARCHAR(20) NOT NULL DEFAULT '',
  6. `s_sex` VARCHAR(10) NOT NULL DEFAULT '',
  7. PRIMARY KEY(`s_id`)
  8. );
  9. # 课程表
  10. CREATE TABLE `Course`(
  11. `c_id` VARCHAR(20),
  12. `c_name` VARCHAR(20) NOT NULL DEFAULT '',
  13. `t_id` VARCHAR(20) NOT NULL,
  14. PRIMARY KEY(`c_id`)
  15. );
  16. # 教师表
  17. CREATE TABLE `Teacher`(
  18. `t_id` VARCHAR(20),
  19. `t_name` VARCHAR(20) NOT NULL DEFAULT '',
  20. PRIMARY KEY(`t_id`)
  21. );
  22. # 成绩表
  23. CREATE TABLE `Score`(
  24. `s_id` VARCHAR(20),
  25. `c_id` VARCHAR(20),
  26. `s_score` INT(3),
  27. PRIMARY KEY(`s_id`,`c_id`)
  28. );
  29. # 插入学生表测试数据
  30. insert into Student values('01' , '赵雷' , '1990-01-01' , '男');
  31. insert into Student values('02' , '钱电' , '1990-12-21' , '男');
  32. insert into Student values('03' , '孙风' , '1990-05-20' , '男');
  33. insert into Student values('04' , '李云' , '1990-08-06' , '男');
  34. insert into Student values('05' , '周梅' , '1991-12-01' , '女');
  35. insert into Student values('06' , '吴兰' , '1992-03-01' , '女');
  36. insert into Student values('07' , '郑竹' , '1989-07-01' , '女');
  37. insert into Student values('08' , '王菊' , '1990-01-20' , '女');
  38. #课程表测试数据
  39. insert into Course values('01' , '语文' , '02');
  40. insert into Course values('02' , '数学' , '01');
  41. insert into Course values('03' , '英语' , '03');
  42. # 教师表测试数据
  43. insert into Teacher values('01' , '张三');
  44. insert into Teacher values('02' , '李四');
  45. insert into Teacher values('03' , '王五');
  46. #成绩表测试数据
  47. insert into Score values('01' , '01' , 80);
  48. insert into Score values('01' , '02' , 90);
  49. insert into Score values('01' , '03' , 99);
  50. insert into Score values('02' , '01' , 70);
  51. insert into Score values('02' , '02' , 60);
  52. insert into Score values('02' , '03' , 80);
  53. insert into Score values('03' , '01' , 80);
  54. insert into Score values('03' , '02' , 80);
  55. insert into Score values('03' , '03' , 80);
  56. insert into Score values('04' , '01' , 50);
  57. insert into Score values('04' , '02' , 30);
  58. insert into Score values('04' , '03' , 20);
  59. insert into Score values('05' , '01' , 76);
  60. insert into Score values('05' , '02' , 87);
  61. insert into Score values('06' , '01' , 31);
  62. insert into Score values('06' , '03' , 34);
  63. insert into Score values('07' , '02' , 89);
  64. insert into Score values('07' , '03' , 98);

题目是查询和"01"号的同学学习的课程完全相同的其他同学的信息,直接做确实有点麻烦,我们可以先做做这题:查看学了所有课程的同学的信息。

    学了所有课程的同学的信息,那不就是这些同学没有一门课程没有学吗

  1. select * from Student st where not exists(select * from Course c
  2. where not exists(select * from Score sc where sc.c_id = c.c_id
  3. and sc.s_id = st.s_id));

在这里插入图片描述

 然后我们再回过来看这题,是不是和刚才的题一模一样,只不过把所有的课程换成01同学学的课程。

  1. select * from Student st where not exists(select * from
  2. ( select s2.c_id as c_id from Student s1
  3. inner join Score s2 on s1.s_id = s2.s_id where s1.s_id = 01) t
  4. where not exists (select * from Score sc
  5. where sc.c_id = t.c_id and sc.s_id = st.s_id and st.s_id != 01));

 在这里插入图片描述

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/447801
推荐阅读
  

闽ICP备14008679号