我看到过很多这样的问题。
Select 1
From table
这个1是什么意思,它将如何执行,它将返回什么?
另外,在什么类型的场景中可以使用它?
我看到过很多这样的问题。
Select 1
From table
这个1是什么意思,它将如何执行,它将返回什么?
另外,在什么类型的场景中可以使用它?
当前回答
Select 1 from table被一些数据库用作测试连接的查询,以查看它是否处于活动状态,通常用于从连接池检索或返回连接。
其他回答
Select 1 from table将为表中的每一行返回常量1。当您想要确定record是否匹配where子句和/或join时,它很有用。
一个查询可以有一个HAVING子句而没有GROUP BY子句,尽管这一点并不广为人知。
在这种情况下,HAVING子句应用于整个集合。显然,SELECT子句不能引用任何列,否则您将(纠正)得到错误,“列在SELECT中无效,因为它不包含在GROUP BY中”等。
因此,必须使用文字值(因为SQL不允许结果集为零列——为什么?!),通常使用文字值1 (INTEGER):如果HAVING子句的值为TRUE,则结果集将是一行,其中一列显示值1,否则您将得到空集。
示例:查找一个列是否有多个不同的值:
SELECT 1
FROM tableA
HAVING MIN(colA) < MAX(colA);
原因是另一个,至少对MySQL来说是这样。这是来自MySQL手册
InnoDB在表启动后第一次访问该表时计算索引基数值,而不是将这些值存储在表中。在将数据划分为许多表的系统上,这个步骤会花费大量时间。由于此开销只应用于初始的表打开操作,为了“预热”一个表以供以后使用,可以在启动后立即通过发出SELECT 1 FROM tbl_name LIMIT 1这样的语句来访问它
如果你不知道你的表中是否存在任何数据,你可以使用以下查询:
SELECT cons_value FROM table_name;
例如:
SELECT 1 FROM employee;
它将返回一个包含行总数的列,并且所有行都具有相同的常量值1(这次它为所有行返回1); 如果表中没有行,它将不返回任何内容。
因此,我们使用这个SQL查询来知道表中是否有任何数据&行数表示这个表中有多少行。
Select 1 from table被一些数据库用作测试连接的查询,以查看它是否处于活动状态,通常用于从连接池检索或返回连接。