SELECT 1 FROM TABLE,SQL语句中的1代表什么意思
admin
2023-04-15 02:21:10
0

select 1 from table; 与 select anycol(目的表集合中的任意一行)from table; 与 select from table;
从作用上来说是没有差别的,都是查看是否有记录,一般是作条件查询用的。select 1 from table中的1是一常量(可以为任意数值),查到的所有行的值都是它,但从效率上来说,1>anycol>
,因为不用查字典表。

注意:

当我们只关心数据表有多少记录行而不需要知道具体的字段值时,类似“select 1 from table”是一个很不错的SQL语句写法,它通常用于子查询。
这样可以减少系统开销,提高运行效率。因为这样写的SQL语句,数据库引擎就不会去检索数据表里每条具体的记录和每条记录里每个具体的字段值并将它们放到内存里,而是根据查询到有多少记录行存在就输出多少个“1”,每个“1”代表有1行记录,同时选用数字1还因为它所占用的内存空间最小,当然用数字0的效果也一样。

测试:

  1. select 1 from table 增加临时列,每行的列值是写在select后的数。这条sql语句中是1
  2. select count(1) from table 不管count(a) 的 a值如何变化,得出的值总是table表的行数
  3. select sum(1) from table 计算临时列的和

在Oracle中用 1 测试了一下,发现结果如下:

  1. 测试结果,得出一个行数和table表行数一样的临时列,每行的列值是1;
  2. 得出一个数,该数是table表的行数;
  3. 得出一个数,该数是table表的行数;

然后又用“2”测试,结果如下:

  1. 得出一个行数和table表行数一样的临时列,每行的列值是2;
  2. 得出一个数,该数是table表的行数;
  3. 得出一个数,该数是table表的行数×2的数

再用不同的数测试

  1. 得出一个行数和table表行数一样的临时列,每行的列值是写在select后的数;
  2. 还是得出一个数,该数是table表的行数;
  3. 得出一个数,该数是table表的行数×写在select后的数

综上所述:第一种的写法是增加临时列,每行的列值是写在select后的数;第二种是不管count(a)的a值如何变化,得出的值总是table表的行数;第三种是计算临时列的和。

相关内容

热门资讯

从一座“灯塔工厂”看海辰储能的... 央广网北京5月12日消息(记者 刘家怡)在重庆市铜梁区,每天有超过10万颗储能电芯下线,发往全球市场...
东莞松山湖高新区“两创融合”催... 当科学家听懂了企业话 东莞松山湖高新区“两创融合”催生新能源新动能 问起扎根东莞松山湖的新能源企业和...
厕所内装摄像头要监控啥 澎湃新闻记者 蒋立冬 阳柳厕所内装摄像头要监控啥“中学在男厕所安装摄像头”一事引发关注。5月11日晚...
原创 港... 大家普遍认为目前的任何钢材都经不起海水的侵蚀腐蚀,但是现如今它的到来将打破这一“铁”的定律!那就是S...
会“变形”的检测机器人Haza... 近日,香港生产力促进局、中广核(深圳)运营技术与辐射监测有限公司、中山大学、西安交通大学及本末科技有...
2025年美国制造业回流追踪 创纪录的投资与关税加码之下,美国制造业在2025年依然表现不佳。但可以合理预期,已宣布的投资将在不久...
原创 风... 那天傍晚,车从草原边上开过去,天色刚压下来,远处一排排白色大风机还在慢慢转。同行的人盯着看了半天,突...
官方调查报告:司机吸食打火机气... 11日,辽阳市应急管理局发布辽阳灯塔沈营线(S101)“10·8”较大道路运输事故调查报告。2024...
赖清德窜访媚外,金门老百姓却苦... 探访厦金大桥赖清德“偷渡式”窜访,岛内民众大骂:这边民生受阻,那边你还去给外国人“跪”。反观今年4月...
特朗普访华,通用汽车和福特高层... 【文/观察者网 潘昱辰 编辑/高莘】美国总统特朗普将于5月13-15日对中国进行国事访问。据白宫披露...