2016-01-20 81 views
0

我有一个form.php数组发布到update.php来更新mysql数据库。 其各自的相关部分是:在foreach循环中未定义的数组偏移量通知

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]; 

所有其他数据库字段更新罚款。任何人都可以指出我正确的方向吗?

+0

检查有多少个指标你进入$ _POST ['aid']和$ _POST ['atype'] ...它必须是相同的..否则你会收到偏移错误。 – devpro

+0

如果我使用print_r它给我每个相同的数字。 – user3726827

回答

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] : ''; 
+0

感谢这为我工作。 – user3726827