在foreach循环中带有数组的未定义偏移通知

时间:2016-01-20 14:55:01

标签: php mysql arrays foreach prepared-statement

我有一个form.php,其中有一个数组发布到update.php以更新mysql数据库。 每个的相关部分是:

form.php的

 if ($type == "1")      {echo ' 
    <input type="hidden" id="assettype" name="atype[]" value="'. $row['AType'] .'"/>
    <input type="hidden" id="assetid" name="aid[]" value="'. $row['AID'] .'"/>

    <input  type="text"  name="serialnum[]" value="'. $row['SerialNumber'] .'"/>
    <input type="text"  name="unitsize[]" value="'. $row['UnitSize'] .'"/>
    <input type="text"  name="prop1[]" value="'. $row['Prop1'] .'"/>    
    <input  type="text"  name="latitude[]" value="'. $row['Latitude'] .'"/>
    <input  type="text"  name="longitude[]" value="'. $row['Longitude'] .'"/>
                ';}  
if ($type == "2")       {echo ' 
    <input type="hidden" id="assettype" name="atype[]" value="'. $row['AType'] .'"/>
    <input type="hidden" id="assetid" name="aid[]" value="'. $row['AID'] .'"/>

    <input type="text"  name="serialnum[]" value="'. $row['SerialNumber'] .'"/>
    <input type="text"  name="unitsize[]" value="'. $row['UnitSize'] .'"/>
    <input type="text"  name="prop2[]"  value="'. $row['Prop2'] .'"/>
    <input type="text"  name="latitude[]" value="'. $row['Latitude'] .'"/>
    <input type="text"  name="longitude[]" value="'. $row['Longitude'] .'"/>
                ';}     

Update.php

foreach ($_POST['aid'] as $key=>$assetid) {
$atype = $_POST['atype'][$key];
if ($atype == "1")      {   

    $stmt =  $mysqli->stmt_init();
    $query = "UPDATE asset SET 
             SerialNumber=?,UnitSize=?,Prop1=?,Latitude=?,Longitude=?  WHERE AID = ?";
    if($stmt->prepare($query)) {

    $stmt->bind_param('sdddds', $serialnum, $unitsize, $prop1, $lat, $long, $assetid);

        $assetid = $_POST['aid'][$key];
        $serialnum = $_POST['serialnum'][$key];
        $unitsize = $_POST['unitsize'][$key];
        $prop1 = $_POST['prop1'][$key];
        $lat = $_POST['latitude'][$key];
        $long = $_POST['longitude'][$key];
        $stmt->execute();
    $stmt->close();
    }
}
elseif ($atype == "2")      {   

    $stmt =  $mysqli->stmt_init();
    $query = "UPDATE asset SET 
             SerialNumber=?,Prop2=?, Latitude=?,Longitude=? WHERE AID = ?";
    if($stmt->prepare($query)) {

    $stmt->bind_param('ssdds', $serialnum, $prop2, $lat, $long, $assetid);

        $assetid = $_POST['aid'][$key];
        $serialnum = $_POST['serialnum'][$key];
        $prop2 = $_POST['prop2'][$key];
        $lat = $_POST['latitude'][$key];
        $long = $_POST['longitude'][$key];
        $stmt->execute();
    $stmt->close();
     }
}}

这适用于除阵列中的一个输入之外的所有输入。 我一直得到以下内容:

  

注意:未定义的偏移量:3

涉及以下一行:

$prop2 = $_POST['prop2'][$key];

除此之外,所有其他数据库字段都正常更新。有人能指出我正确的方向吗?

1 个答案:

答案 0 :(得分:0)

您应该为此数组输入字段使用相同的名称。即prop [],但你使用了prop1 []和prop2 []。

if ($type == "1")      {echo ' 
    <input type="hidden" id="assettype" name="atype[]" value="'. $row['AType'] .'"/>
    <input type="hidden" id="assetid" name="aid[]" value="'. $row['AID'] .'"/>

    <input  type="text"  name="serialnum[]" value="'. $row['SerialNumber'] .'"/>
    <input type="text"  name="unitsize[]" value="'. $row['UnitSize'] .'"/>
    <input type="text"  name="prop[]" value="'. $row['Prop1'] .'"/>    
    <input  type="text"  name="latitude[]" value="'. $row['Latitude'] .'"/>
    <input  type="text"  name="longitude[]" value="'. $row['Longitude'] .'"/>
                ';}  
if ($type == "2")       {echo ' 
    <input type="hidden" id="assettype" name="atype[]" value="'. $row['AType'] .'"/>
    <input type="hidden" id="assetid" name="aid[]" value="'. $row['AID'] .'"/>

    <input type="text"  name="serialnum[]" value="'. $row['SerialNumber'] .'"/>
    <input type="text"  name="unitsize[]" value="'. $row['UnitSize'] .'"/>
    <input type="text"  name="prop[]"  value="'. $row['Prop2'] .'"/>
    <input type="text"  name="latitude[]" value="'. $row['Latitude'] .'"/>
    <input type="text"  name="longitude[]" value="'. $row['Longitude'] .'"/>
                ';}     

在行动页面更新中如下:

$prop2 = $_POST['prop'][$key];

我不知道你使用了什么逻辑,如果使用了逻辑错误,

$prop2 = !empty($_POST['prop2'][$key]) ? $_POST['prop2'][$key] : '';