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

Select 1  
From table

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

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


当前回答

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

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

如果你只是想根据WHERE子句检查是真还是假,从表中选择1,其中条件是最便宜的方法。

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

Select * from [table_name]

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

select 1 from Users

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

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

我看到它总是用于SQL注入,例如:

www.urlxxxxx.com/xxxx.asp?id=99 union select 1、2、3、4、5、6、7、8、9 from database;

这些数字可用于猜测数据库存在的位置,并猜测您指定的数据库的列名。以及表的值。