余姚网站建设报价,网页设计工资条,网站产品 模块,网络公司简介模板exists : 强调的是是否返回结果集#xff0c;不要求知道返回什么, 比如#xff1a;select name from student where sex m and mark exists(select 1 from grade where ...) ,只要exists引导的子句有结果集返回#xff0c;那么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引导的子句只能返回一个字段比如select name from student where sex m and mark in (select 1,2,3 from grade where ...)in子句返回了三个字段这是不正确的exists子句是允许的但in只允许有一个字段返回在123中随便去了两个字段即可。而not exists 和not in 分别是exists 和 in 的 对立面。exists (sql 返回结果集为真)not exists (sql 不返回结果集为真)一种通俗的可以理解为将外查询表的每一行代入内查询作为检验如果内查询返回的结果取非空值则EXISTS子句返回TRUE这一行行可作为外查询的结果行否则不能作为结果。分析器会先看语句的第一个词当它发现第一个词是SELECT关键字的时候它会跳到FROM关键字然后通过FROM关键字找到表名并把表装入内存。接着是找WHERE关键字如果找不到则返回到SELECT找字段解析如果找到WHERE则分析其中的条件完成后再回到SELECT分析字段。最后形成一张我们要的虚表。WHERE关键字后面的是条件表达式。条件表达式计算完成后会有一个返回值即非0或0非0即为真(true)0即为假(false)。同理WHERE后面的条件也有一个返回值真或假来确定接下来执不执行SELECT。分析器先找到关键字SELECT然后跳到FROM关键字将STUDENT表导入内存并通过指针找到第一条记录接着找到WHERE关键字计算它的条件表达式如果为真那么把这条记录装到一个虚表当中指针再指向下一条记录。如果为假那么指针直接指向下一条记录而不进行其它操作。一直检索完整个表并把检索出来的虚拟表返回给用户。EXISTS是条件表达式的一部分它也有一个返回值(true或false)。EXISTS与IN的使用效率的问题通常情况下采用exists要比in效率高因为IN不走索引但要看实际情况具体使用IN适合于外表大而内表小的情况EXISTS适合于外表小而内表大的情况。