为什么要select 1呢,,,这个1是什么意思??

 我来答
渠景中8W
推荐于2017-12-16 · TA获得超过544个赞
知道小有建树答主
回答量:369
采纳率:100%
帮助的人:291万
展开全部
select 1 from mytable;与select anycol(目的表集合中的任意一行) from mytable;与select * from mytable 作用上来说是没有差别的,都是查看{{是否有记录}},一般是作条件用的。select 1 from 中的1是一常量,查到的所有行的值都是它,但从效率上来说,1>anycol>*,因为不用查字典表。
追问
以前用过百度知道,都好久不用了,现在开始用了,不知道咋向你发消息。。就是内部消息,我咋没有找到呢,以前还用过呢!!!
追答
1 是一个常量 , 如果表中有值,那么查询出来的结果集合有多少个1代表表中有多少条表记录。
巴黎的雨37
2018-03-31 · TA获得超过3087个赞
知道小有建树答主
回答量:50
采纳率:100%
帮助的人:7644
展开全部

有时候为了提高效率,只是为了测试下某个表中是否存在记录,就用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

这是条可以执行的语句

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
西门公子庆
2012-02-27 · TA获得超过1879个赞
知道小有建树答主
回答量:482
采纳率:100%
帮助的人:262万
展开全部
select 1 其实没什么特别的意思,就是select 一个指定的值,因为我的目地是判断是否有存在,所以不需要返回任何字段信息。写select 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啊。
来自:求助得到的回答
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式