MySQL关于IN和EXISTS比较读完之后(MySQL关于IN和EXISTS比较读完之后)
MySQL关于IN和EXISTS比较读完之后(MySQL关于IN和EXISTS比较读完之后)in()后面的子查询 是返回结果集的 换句话说执行次序和exists()不一样.子查询先产生结果集 然后主查询再去结果集里去找符合要求的字段列表去.符合要求的输出 反之则不输出.exists()后面的子查询被称做相关子查询 他是不返回列表的值的.只是返回一个ture或false的结果 其运行方式是先运行主查询一次 再去子查询里查询与其对应的结果 如果是ture则输出 反之则不输出.再根据主查询中的每一行去子查询里去查询.exists的用法跟in不一样,一般都需要和子表进行关联,而且关联时,需要用索引,这样就可以加快速度。确定给定的值是否与子查询或列表中的值相匹配。指定一个子查询,检测行的存在。
1.exist not exist一般都是与子查询一起使用. In可以与子查询一起使用 也可以直接in (a b.....)。
2.exist会针对子查询的表使用索引. not exist会对主子查询都会使用索引. in与子查询一起使用的时候 只能针对主查询使用索引. not in则不会使用任何索引. 注意 一直以来认为exists比in效率高的说法是不准确的。
in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询。
IN 其实与等于相似,比如in(1 2) 就是 = 1 or = 2的一种简单写法,所以一般在元素少的时候使用IN,如果多的话就用exists
exists的用法跟in不一样,一般都需要和子表进行关联,而且关联时,需要用索引,这样就可以加快速度。
IN确定给定的值是否与子查询或列表中的值相匹配。
EXISTS指定一个子查询,检测行的存在。
比较使用 EXISTS 和 IN 的查询exists()后面的子查询被称做相关子查询 他是不返回列表的值的.只是返回一个ture或false的结果 其运行方式是先运行主查询一次 再去子查询里查询与其对应的结果 如果是ture则输出 反之则不输出.再根据主查询中的每一行去子查询里去查询.
in()后面的子查询 是返回结果集的 换句话说执行次序和exists()不一样.子查询先产生结果集 然后主查询再去结果集里去找符合要求的字段列表去.符合要求的输出 反之则不输出.
关注感谢阅读,如果这篇文章帮助了您,欢迎 点赞 ,收藏,关注,转发 哟。您的帮助是我们前行的动力,我们会提供更多有价值的内容给大家... 谢谢!