小编str*_*kol的帖子

带LIMIT1的SQL返回所有记录

我犯了一个错误并输入了:

SELECT * FROM table LIMIT1

代替

SELECT * FROM table LIMIT 1(注意之间的空间LIMIT1)

在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
Run Code Online (Sandbox Code Playgroud)

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

sql

6
推荐指数
1
解决办法
463
查看次数

标签 统计

sql ×1