有时候为了提高效率,只是为了测试下某个表中是否存在记录,就用1来代替。
例如我的student中有学生信息表,我只想知道里面有没有数据并不在乎数据是哪些,就可以select 1 from student ,这样大大提高查询速度,选出100行个1,说明有100条学生信息。常搭配 exists方法当条件使用。
所以说,当运用exists到相关子查询时,无所谓子表里SELECT后面跟的是什么,英文我们只需要exists返回值为true或者false即可。
例子:
select a.first_name,a.last_name
from employees a
where EXISTS
(select 1
from dept_emp b
where a.emp_no=b.emp_no)
如果有查询结果,查询结果就会全部被1替代(当不需要知道结果是什么,只需要知道有没有结果的时候会这样用),可以提高语句的运行效率,在大数据量的情况下,提升效果非常明显