数据库:番外篇-IN和EXISTS的用法和区别的比较

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()不一样.子查询先产生结果集,然后主查询再去结果集里去找符合要求的字段列表去.符合要求的输出,反之则不输出.

文章转于:https://blog.csdn.net/u012110719/article/details/48094181

--------------------------------------------------------------------------------

                SELECT
			tct.id teamId,tct.name teamName,tclo.id centerId, tclo.`name` centerName,tcl.id lawfirmId,tcl.name lawfirmName
		FROM
			t_coa_team tct
		left join t_coa_lawfirm_org tclo
			on tct.center_id = tclo.id
		left join t_coa_lawfirm tcl
			on tct.lawfirm_id = tcl.id
		WHERE
			EXISTS (
		SELECT
			1
		FROM
			t_coa_case_archive_auth tccaa
		WHERE
			tccaa.case_id = 555
			AND tct.id = tccaa.team_id
			)

先查询t_coa_case_archive_auth里面case_id=555有多少条记录存在

在用team_id和t_coa_team的id进行关联,存在才会输出


阅读更多 登录后自动展开
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页