更新最后一条记录 - 在mysql查询中找不到语法错误

时间:2012-04-04 08:58:38

标签: mysql

我需要这个查询 - 更新最后一条记录。

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附近有什么问题?

2 个答案:

答案 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;