php-mysql更新1查询更多


php mysql update 1 query instead much more

我有一个id和排序的表,我需要创建这个更新

mysql_query("
UPDATE `steps` SET sort = '2' WHERE id = '9' ;
UPDATE `steps` SET sort = '1' WHERE id = '5' ;
UPDATE `steps` SET sort = '3' WHERE id = '6' ;
UPDATE `steps` SET sort = '4' WHERE id = '4' ;
UPDATE `steps` SET sort = '5' WHERE id = '2' ;
UPDATE `steps` SET sort = '6' WHERE id = '1' ;
UPDATE `steps` SET sort = '7' WHERE id = '8' ;
");

像这样的不正确

mysql_query("UPDATE `steps` SET sort = '2' WHERE id = '9' , sort = '1' WHERE id = '5' , sort = '3' WHERE id = '6' ;");

如何缩小它?你有什么想法吗?

mysql_query不支持使用单个字符串运行多个查询。MySQLI通过mysqli_multi_query对此提供支持,但我个人认为这是一个反模式。据我所知,PDO不支持它

您可以使用多个mysql_query语句,但也可以在一个查询中完成:

UPDATE steps SET sort = CASE
    WHEN id = 9 THEN 2
    WHEN id = 5 THEN 1
    ELSE sort
END CASE

在新代码中使用PDOmysqli而不是ext/mysql