-3

更新:

我从$_POST['changed'].

数组结构如下所示:

Array
(
    [0] => Array
        (
            [recid] => 1
            [nachname] => Müller7777
        )

    [1] => Array
        (
            [recid] => 3
            [vorname] => Maria123
        )

)

我在第 3 行遇到此错误:致命错误:函数名称必须是字符串

$uarr=array();

foreach ($_POST['changed'] as $a) {
  list($x,$k)=array_keys($a);
  list($y,$v)=array_values($a);

  $uarr[$y][]="$k='$v'";
}

foreach ($uarr as $k=>$v) {
  $sql = "";
  $sql .="UPDATE tbl SET ".join(",",$v)." WHERE recid=$k";
  // send UPDATE ...
}
file_put_contents('filename2.txt', $sql);

在我进行最终的数据库更新之前,我想检查创建的数组是否完成了它的工作。这就是为什么我想先将 $sql 变量写入 txt 文件。

------------------------------------------------

解决方案:

检查是否$_POST['changed'] == null是这个问题的最终答案。

if ($_POST['changed'] == null) {

} else {

$uarr=array();
$b = $_POST['changed'];
foreach ($b as $a) {
  list($x,$k)=array_keys($a);
  list($y,$v)=array_values($a);
  // $x contains the `recid` key 
  // $y ...                  value
  $uarr[$y][]="$k='$v'";
}



foreach ($uarr as $k=>$v) {
  $sql = "";
  $sql .="UPDATE tbl SET ".join(",",$v)." WHERE recid=$k";
  // send UPDATE ...
}
file_put_contents('filename2.txt', $sql);

}
4

2 回答 2

0

尝试这样做:

$BigArray = $_POST['changed'];
$LengthOfArray = sizeof($BigArray);

for ($i = 0; $i < $LengthOfArray ; $i++) {

    $SubArray = $BigArray[$i];

    // Call the update/insert here
    // $SubArray['recid'] is the ID
    // $SubArray['vorname'] is the name
}
于 2013-09-01T13:35:30.680 回答
0

在运行各个UPDATE语句之前-是的,对于每个值,您应该发送一个语句-您可以首先在关联数组中recid收集每个受影响的值,例如recid

$uarr=array();
foreach ($_POST['changed'] as $a) {
  list($x,$k)=array_keys($a);
  list($y,$v)=array_values($a);
  // $x contains the `recid` key 
  // $y ...                  value
  $uarr[$y][]="$k='$v'";
}

然后做另一个循环

foreach ($uarr as $k=>$v) {
  $sql="UPDATE tbl SET ".join(",",$v)." WHERE recid=$k";
  // send UPDATE ...
}

但是,当然,这只有在$_POST('changed')数组符合所描述的格式和顺序时才能正常工作。最后,到目前为止,此代码中没有任何内容可以保护您免受 SQL 注入。

于 2013-09-01T13:45:33.380 回答