为什么要select 1呢,,,这个1是什么意思??
展开全部
select 1 from mytable;与select anycol(目的表集合中的任意一行) from mytable;与select * from mytable 作用上来说是没有差别的,都是查看{{是否有记录}},一般是作条件用的。select 1 from 中的1是一常量,查到的所有行的值都是它,但从效率上来说,1>anycol>*,因为不用查字典表。
追问
以前用过百度知道,都好久不用了,现在开始用了,不知道咋向你发消息。。就是内部消息,我咋没有找到呢,以前还用过呢!!!
追答
1 是一个常量 , 如果表中有值,那么查询出来的结果集合有多少个1代表表中有多少条表记录。
展开全部
有时候为了提高效率,只是为了测试下某个表中是否存在记录,就用1来代替。
例如我的student 中 有学生信息表,我只想知道里面有没有数据并不在乎数据是哪些,就可以
select 1 from student ,这样大大提高查询速度,选出100行个1,说明有100条学生信息。
常搭配 exists方法当条件使用。
select * from table where 1=1中的1=1是什么意思?
就是条件为真的意思,就这条语句来说就等同于select * from table(1=1就是条件为真)
select * from table where 1=1这样写一般是编程时查询语句有判断拼接条件时用的
如 :
str=“select * from table where”;
if(a=1){str=str+" user=abc";}
if(b=1){str=str+" and pass=123";}
当IF条件成立时select * from table where and user=abc and pass=123
这是条可以执行的语句
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
select 1 其实没什么特别的意思,就是select 一个指定的值,因为我的目地是判断是否有存在,所以不需要返回任何字段信息。写select 1比返回字段信息效率更高。。
select 1 from table where 1=1 。。
这样查询结果就是 1 ,行数等同于 select * from table where 1=1 。。的行数。
select 1 from table where 1=1 。。
这样查询结果就是 1 ,行数等同于 select * from table where 1=1 。。的行数。
追问
比方说:select 1 from employee, 表employee里有6行数据,那么select 1 from employee返回的结果却是竖着的6个1呢?
追答
嗯,因为有6条记录,所以是6个1啊。
来自:求助得到的回答
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询