将数组的顺序插入到数据库中


insert order of array into database

我用javascript和php创建了一个表单。我使用了一个文本框,例如

 <input type="textbox" name="listid" value="" />  

我将从 $_POST['listid'] 获得一个像 4,6,12,9 等这样的数组;我可以使用序列化将此值插入数据库,并通过反序列化来检索它。但是我需要做的是,插入 1 表示 listid=4,2 表示 listid=6,3 表示 listid=12,4 表示 listid=9。我用过

$count=0;
 foreach($_POST['listid]' as $id)
        {
            $count++;
    $db->update('lists',array('order'=>$count),'id ='.$db->quote($id));
        }

但它不起作用。仅更新第一个值(列表 ID = 4)

我需要做什么?有人请帮忙吗??

谢谢!

你不会从$_POST['listid]收到一个数组,你会得到一个字符串。首先将该字符串拆分为一个数组,然后实现逻辑。

$arrListId = split(',', $_POST['listid]);

试试这个。

<?php
$count=0;
 foreach($_POST['listid'] as $id)
        {
            $count++;
    $db->update('lists',array('order'=>$count),'id ='.$db->quote($id));
        }
?>

删除 $count=0;脱离 for 循环

你可以试试

$count=0;
foreach($_POST['listid]' as $id)
{   
    $count++;
    $data   =   array('order'=>$count);
    $db->update('lists',$data,$this->_db->quoteInto('id = ?',$id));
}

我希望这可能有效