1

我有一个场景,我正在考虑根据现有列中的旧值用新值更新类别列中的值。类别在单独的表中进行了更改,并且需要在此表中更新以反映更改。

我正在使用准备好的语句和两个数组来审查要替换的不同值:

$category = array($_POST['cat1'],$_POST['cat2'],$_POST['cat3'],$_POST['cat4']);
$oldCategory = array($_POST['catOld1'],$_POST['catOld2'],$_POST['catOld3'],$_POST['catOld4']);

for ($i=0;$i<4;$i++) {
    $strg="UPDATE table_name SET CATEGORY = REPLACE (CATEGORY, ?, ?)";
    $sql = $mysqli->prepare($strg) or die($db->error());
    $sql->bind_param('ss', $oldCategory[$i], $category[$i]);
    $sql->execute();
}

我认为这是我的 REPLACE 语句的语法与准备好的语句有关,它只会导致挂起,但在网上任何地方都找不到正确格式的参考。任何帮助表示赞赏。谢谢。

更新:好的,其中一件奇怪的事情:它现在正在工作。为什么?我不确定。墨菲定律总是给我们带来沉重打击。Wrikken,你是对的:语法没有错。希望我能改装你。

不过,希望以上内容对其他人有用。我花了很多时间,没有在线参考来解决这个问题。希望有用。

4

1 回答 1

0

用这个 :

$strg="UPDATE table_name SET CATEGORY = REPLACE (CATEGORY,$oldCategory[$i],$category[$i])";

代替这个:

$strg="UPDATE table_name SET CATEGORY = REPLACE (CATEGORY, ?, ?)";
于 2013-10-19T02:24:15.433 回答