现在是少女时代,以后是少女时代,永远是少女时代!
sone :少时的假粉丝

select 1 from 是什么意思?或者select count(1) from 是什么意思?有什么作用?



一、select 1 from 的作用


1、select 1 from mytable 与 select anycol(目的表集合中的任意一行)from mytable、select * from mytable 作用上来说是没有差别的,都是查看是否有记录。  --虽然说没有区别,但还是好奇到底为什么用select 1 from

2、select 1 from 中的1是一常量,查到的所有行的值都是它,但从效率上来说,1>anycol>*,因为不用查字典表。 --这里所说的查到满足筛选条件的记录,会生成一个临时列,而且值是1,这里有个性能点,就是执行效率 1>anycol>*,执行效率是最快的;有数据就返回1,没数据返回null

3、查看记录条数可以用select sum(1) from mytable;等价于select sum(*) f
rom mytable。或者 select count(1) from mytable;等价于select count(*) from mytable。 

4、例如select top 1 1 from mytable 用来判断表是否有记录,如有记录则显示一个 1,没有则不显示。

 

 

二、什么时候适用?


一般用来当做判断子查询是否成功(即是否有满足条件的时候使用),常用于exists,子查询中,

比如
select * from ta where  exists (select 1 from ta.id = tb.id)
这个判断就是(select 1 from ta.id = tb.id)这个查询如果有返回值的话表示当前查询满足条件,一般来说就简单话的用select 1

 

这种查询写法,在性能调优的时候,可能会经常用到,执行效率比较快。


参考文章:

select 1 from 是什么意思?有什么作用?


琼ICP备16001221号-1