0

我有一个方法,必须更改大约 20 行。我为每个 ajax 传递一个像“14-33-61-10 ...”这样的字符串来保存一些行的顺序。这是我的实际(工作)代码:

$explode = explode('--',$_POST['data']); // -> array('0'=>'8', '1'=>'4', '2'=> ... )
$i = 1;
foreach( $explode as $task ) {
    if( !is_int($task) ) continue;
    $exec = $project->exec("UPDATE tasks SET pos=$i WHERE rowid=". $task );
    $i++;
}

我的问题是,它需要大约 1 秒。我的问题:有没有办法只用一个查询来编辑多行?

4

3 回答 3

3

当然,发送如下 SQL 字符串:

update  tasks 
set     pos =
        case rowid
        when 13 then 1
        when 33 then 2
        when 61 then 3
        when 10 then 4
        end
where   rowid in (13,33,61,10)

13-33-61-10to的翻译(13,33,61,10) 最好在 PHP 中完成。

于 2013-08-06T09:31:42.953 回答
0

如果范围很短,那么我们可以使用 ID IN (ids) 参数。

UPDATE `profile` SET `app_status`=3  WHERE `id` IN (3,37,95,136,1087,1795,1817)

如果它很长并且我们知道该范围,让我们使用 BETWEEN value AND value 参数。

UPDATE `profile` SET `app_status`=3  WHERE `id` BETWEEN 3904 AND 3918
于 2013-08-06T10:27:28.610 回答
-1
$explode = explode('--',$_POST['data']); // -> array('0'=>'8', '1'=>'4', ... )
$i = 1;
$sql = "";
foreach($explode as $task)
{
    if(!is_int($task)) continue;
    $sql .= "UPDATE tasks SET pos=$i WHERE rowid=$task;";
    $i++;
}
$project->exec($sql);
于 2013-08-06T09:32:31.690 回答