我看到过很多这样的问题。
Select 1
From table
这个1是什么意思,它将如何执行,它将返回什么?
另外,在什么类型的场景中可以使用它?
我看到过很多这样的问题。
Select 1
From table
这个1是什么意思,它将如何执行,它将返回什么?
另外,在什么类型的场景中可以使用它?
当前回答
原因是另一个,至少对MySQL来说是这样。这是来自MySQL手册
InnoDB在表启动后第一次访问该表时计算索引基数值,而不是将这些值存储在表中。在将数据划分为许多表的系统上,这个步骤会花费大量时间。由于此开销只应用于初始的表打开操作,为了“预热”一个表以供以后使用,可以在启动后立即通过发出SELECT 1 FROM tbl_name LIMIT 1这样的语句来访问它
其他回答
如果你不知道你的表中是否存在任何数据,你可以使用以下查询:
SELECT cons_value FROM table_name;
例如:
SELECT 1 FROM employee;
它将返回一个包含行总数的列,并且所有行都具有相同的常量值1(这次它为所有行返回1); 如果表中没有行,它将不返回任何内容。
因此,我们使用这个SQL查询来知道表中是否有任何数据&行数表示这个表中有多少行。
它做了它所说的——它总是返回整数1。它用于检查是否存在与where子句匹配的记录。
它简单地表示您正在从表,,,,中检索数字第一列 select empl_num,Empl_no From Employees; 这里你使用select 1 from Employees; 这意味着您正在检索Emply_num列。 谢谢
如果你的意思是
SELECT * FROM AnotherTable
WHERE EXISTS (SELECT 1 FROM table WHERE...)
那么1优于
SELECT * FROM AnotherTable
WHERE EXISTS (SELECT * FROM table WHERE...)
EXISTS中的1或*被忽略,你可以按照ANSI SQL 1992标准的第191页写:
SELECT * FROM AnotherTable
WHERE EXISTS (SELECT 1/0 FROM table WHERE...)
Select 1 from table将为表中的每一行返回常量1。当您想要确定record是否匹配where子句和/或join时,它很有用。