我需要这个查询 - 更新最后一条记录。
UPDATE changes SET checked='' WHERE item_id = 119898 AND type = 'example_edit' AND checked != 'restored' ORDER BY id DESC LIMIT 1, 1
数据库回声:
#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ' 1' at line 1
1附近有什么问题?
答案 0 :(得分:0)
标准更新声明
UPDATE [LOW_PRIORITY] [IGNORE] table_reference
SET col_name1={expr1|DEFAULT} [, col_name2={expr2|DEFAULT}] ...
[WHERE where_condition]
[ORDER BY ...]
[LIMIT row_count]
为你的情况试试这个
UPDATE changes SET checked='' WHERE item_id = 119898 AND type = 'example_edit' AND checked != 'restored' ORDER BY id DESC LIMIT 1
尝试它将真正帮助您,代码测试。 更新中的限制只能使用行计数而不是1,1等。
答案 1 :(得分:0)
LIMIT可以与UPDATE一起使用,但仅限行数。请参阅this。
LIMIT子句限制了可以更新的行数。
所以这个查询应该有效 -
UPDATE
changes
SET
checked = ''
WHERE item_id = 119898
AND TYPE = 'example_edit'
AND checked != 'restored'
ORDER BY id DESC
LIMIT 1;