今天在学习公司业务的时候,看到了程序中使用的exists关键字,这个关键字是数据库中的,在大学的时候,我就没有很好地理解这个关键字,到现在还是不太理解,总是觉得没有in关键字好用。
现在看到这个关键字我觉得很是胆怯啊,这次是我去读程序,而不是写程序了。不能够用in关键字去替代exists了,没办法我只好硬着头皮网上冲了。
我首先在网上看了看exists的相关用法和优点,看完之后才发现在有些时候exists的效率要比in关键字的效率高很多。
exists关键字主要适用于带有子查询的查询语句中,是这样的,如果主查询的数据量比子查询的数据量要大很多,这种情况下不建议使用exists关键字,取而代之的应该是in关键字;相反如果主查询的数据量比子查询的数据量要下很多,这种情况下就建议使用exists关键字了,而且效率会提高很多。
具体的例子在网上有很多,我下面就贴一个网上现成的例子:
1) select * from T1 where exists(select 1 from T2 where T1.a=T2.a) ;
T1数据量小而T2数据量非常大时,T1<<T2 时,1) 的查询效率高。
2) select * from T1 where T1.a in (select T2.a from T2) ;
T1数据量非常大而T2数据量小时,T1>>T2 时,2) 的查询效率高。
exists 用法:
请注意 1)句中的有颜色字体的部分 ,理解其含义;
其中 “select 1 from T2 where T1.a=T2.a” 相当于一个关联表查询,相当于
“select 1 from T1,T2 where T1.a=T2.a”
现在看到这个关键字我觉得很是胆怯啊,这次是我去读程序,而不是写程序了。不能够用in关键字去替代exists了,没办法我只好硬着头皮网上冲了。
我首先在网上看了看exists的相关用法和优点,看完之后才发现在有些时候exists的效率要比in关键字的效率高很多。
exists关键字主要适用于带有子查询的查询语句中,是这样的,如果主查询的数据量比子查询的数据量要大很多,这种情况下不建议使用exists关键字,取而代之的应该是in关键字;相反如果主查询的数据量比子查询的数据量要下很多,这种情况下就建议使用exists关键字了,而且效率会提高很多。
具体的例子在网上有很多,我下面就贴一个网上现成的例子:
1) select * from T1 where exists(select 1 from T2 where T1.a=T2.a) ;
T1数据量小而T2数据量非常大时,T1<<T2 时,1) 的查询效率高。
2) select * from T1 where T1.a in (select T2.a from T2) ;
T1数据量非常大而T2数据量小时,T1>>T2 时,2) 的查询效率高。
exists 用法:
请注意 1)句中的有颜色字体的部分 ,理解其含义;
其中 “select 1 from T2 where T1.a=T2.a” 相当于一个关联表查询,相当于
“select 1 from T1,T2 where T1.a=T2.a”