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

Select 1  
From table

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

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


当前回答

这只是为了方便使用IF EXISTS()。否则你可以跟我走

Select * from [table_name]

在'IF EXISTS'的情况下,我们只需要知道任何具有指定条件的行存在与否与行内容无关。

select 1 from Users

上面的示例代码,返回no。等于no。单列中有1的用户

其他回答

这只是为了方便使用IF EXISTS()。否则你可以跟我走

Select * from [table_name]

在'IF EXISTS'的情况下,我们只需要知道任何具有指定条件的行存在与否与行内容无关。

select 1 from Users

上面的示例代码,返回no。等于no。单列中有1的用户

SELECT 1 FROM TABLE_NAME表示“从表中返回1”。它本身是非常不起眼的,所以通常会与WHERE和EXISTS一起使用(正如@gbn所指出的,这不一定是最佳实践,然而,它是足够常见的,即使它没有真正的意义(也就是说,我将使用它,因为其他人使用它,它“更明显”。当然,这可能是一个有鸡还是有蛋的问题,但我通常不会去思考))。

 SELECT * FROM TABLE1 T1 WHERE EXISTS (
     SELECT 1 FROM TABLE2 T2 WHERE T1.ID= T2.ID
 );

基本上,上面的代码将返回表1中与表2中的ID相对应的所有内容。(显然,这是一个人为的例子,但我相信它传达了这个想法。就我个人而言,我可能会这样做:SELECT * FROM TABLE1 T1 WHERE ID IN (SELECT ID FROM TABLE2);因为我认为这对读者来说要明确得多,除非有令人信服的理由不这样做)。

EDIT

There actually is one case which I forgot about until just now. In the case where you are trying to determine existence of a value in the database from an outside language, sometimes SELECT 1 FROM TABLE_NAME will be used. This does not offer significant benefit over selecting an individual column, but, depending on implementation, it may offer substantial gains over doing a SELECT *, simply because it is often the case that the more columns that the DB returns to a language, the larger the data structure, which in turn mean that more time will be taken.

原因是另一个,至少对MySQL来说是这样。这是来自MySQL手册

InnoDB在表启动后第一次访问该表时计算索引基数值,而不是将这些值存储在表中。在将数据划分为许多表的系统上,这个步骤会花费大量时间。由于此开销只应用于初始的表打开操作,为了“预热”一个表以供以后使用,可以在启动后立即通过发出SELECT 1 FROM tbl_name LIMIT 1这样的语句来访问它

它做了它所说的——它总是返回整数1。它用于检查是否存在与where子句匹配的记录。

它简单地表示您正在从表,,,,中检索数字第一列 select empl_num,Empl_no From Employees; 这里你使用select 1 from Employees; 这意味着您正在检索Emply_num列。 谢谢