带LIMIT1的SQL返回所有记录

前端之家收集整理的这篇文章主要介绍了带LIMIT1的SQL返回所有记录前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我犯了一个错误并输入了:

SELECT * FROM表LIMIT1

代替

SELECT * FROM表LIMIT 1(注意LIMIT和1之间的空格)

MySQL的CLI中.我希望收到某种解析错误,但我很惊讶,因为查询返回了表中的所有记录.我的第一个想法是“愚蠢的MysqL,我打赌这会在Postgresql中返回错误”,但Postgresql也返回了所有记录.然后用sqlite测试它 – 结果相同.

经过一番挖掘,我意识到我在桌子后输入的内容并不重要.只要没有WHERE / ORDER / GROUP子句:

SELECT * FROM table SOMETHING -- works and returns all records in table

SELECT * FROM table WHERE true SOMETHING -- doesn't work - returns parse error

我想这是一种标准化的行为,但我找不到任何解释为什么会这样.有任何想法吗?

解决方法

您的第一个查询使用表别名等效于此查询
SELECT * FROM yourtable AS LIMIT1

AS关键字是可选的.表别名允许您使用别名LIMIT1.foo而不是原始表名来引用该表的列.如果您希望在查询中为表提供更短或更具描述性的别名,则使用别名会很有用.如果将表连接到自身,则必须使用别名.

SQL lite documentation

猜你在找的MsSQL相关文章