我看到过很多这样的问题。
Select 1
From table
这个1是什么意思,它将如何执行,它将返回什么?
另外,在什么类型的场景中可以使用它?
我看到过很多这样的问题。
Select 1
From table
这个1是什么意思,它将如何执行,它将返回什么?
另外,在什么类型的场景中可以使用它?
当前回答
如果你不知道你的表中是否存在任何数据,你可以使用以下查询:
SELECT cons_value FROM table_name;
例如:
SELECT 1 FROM employee;
它将返回一个包含行总数的列,并且所有行都具有相同的常量值1(这次它为所有行返回1); 如果表中没有行,它将不返回任何内容。
因此,我们使用这个SQL查询来知道表中是否有任何数据&行数表示这个表中有多少行。
其他回答
如果你不知道你的表中是否存在任何数据,你可以使用以下查询:
SELECT cons_value FROM table_name;
例如:
SELECT 1 FROM employee;
它将返回一个包含行总数的列,并且所有行都具有相同的常量值1(这次它为所有行返回1); 如果表中没有行,它将不返回任何内容。
因此,我们使用这个SQL查询来知道表中是否有任何数据&行数表示这个表中有多少行。
它做了它所说的——它总是返回整数1。它用于检查是否存在与where子句匹配的记录。
对于表中的每条记录,结果都是1。
更具体地说,您将使用这个来做
SELECT 1 FROM MyUserTable WHERE user_id = 33487
而不是做
SELECT * FROM MyUserTable WHERE user_id = 33487
因为你不关心结果。对于数据库来说,请求数字1非常容易(因为它不需要进行任何查找)。
我看到它总是用于SQL注入,例如:
www.urlxxxxx.com/xxxx.asp?id=99 union select 1、2、3、4、5、6、7、8、9 from database;
这些数字可用于猜测数据库存在的位置,并猜测您指定的数据库的列名。以及表的值。