我看到过很多这样的问题。

Select 1  
From table

这个1是什么意思,它将如何执行,它将返回什么?

另外,在什么类型的场景中可以使用它?


当前回答

更具体地说,您将使用这个来做

SELECT 1 FROM MyUserTable WHERE user_id = 33487

而不是做

SELECT * FROM MyUserTable WHERE user_id = 33487

因为你不关心结果。对于数据库来说,请求数字1非常容易(因为它不需要进行任何查找)。

其他回答

更具体地说,您将使用这个来做

SELECT 1 FROM MyUserTable WHERE user_id = 33487

而不是做

SELECT * FROM MyUserTable WHERE user_id = 33487

因为你不关心结果。对于数据库来说,请求数字1非常容易(因为它不需要进行任何查找)。

一个查询可以有一个HAVING子句而没有GROUP BY子句,尽管这一点并不广为人知。

在这种情况下,HAVING子句应用于整个集合。显然,SELECT子句不能引用任何列,否则您将(纠正)得到错误,“列在SELECT中无效,因为它不包含在GROUP BY中”等。

因此,必须使用文字值(因为SQL不允许结果集为零列——为什么?!),通常使用文字值1 (INTEGER):如果HAVING子句的值为TRUE,则结果集将是一行,其中一列显示值1,否则您将得到空集。

示例:查找一个列是否有多个不同的值:

SELECT 1
  FROM tableA
HAVING MIN(colA) < MAX(colA);

Select 1 from table将为表中的每一行返回常量1。当您想要确定record是否匹配where子句和/或join时,它很有用。

这意味着你想要一个值“1”作为输出,或者大部分时间用作内部查询,因为出于某种原因,你想要根据内部查询的结果计算外部查询。不是所有的时候你都用1,但是你有一些特定的值…

这将静态地为您提供值1的输出。

如果你的意思是

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...)