php mysql:从数据库中选择并填充表单

时间:2016-01-18 06:30:12

标签: php mysql populate

我想从我的数据库填充客户端的地址。 我使用此代码从db:

中进行选择
$stmt = $conn->prepare("SELECT * FROM peopleaddress WHERE peopleID=?");
    if ( !$stmt ) {die(printf("Error: %s.\n", mysqli_stmt_error($stmt) ) );}
else if ( !$stmt->bind_param('i', $peopleID ) ) {die(printf("Error: %s.\n", mysqli_stmt_error($stmt) ) );}
else if ( !$stmt->execute() ) { die(printf("Error: %s.\n", mysqli_stmt_error($stmt) ) ); }
else {
    $result = $stmt->get_result();

    while($row = $result->fetch_assoc()) {
        $addressID_array = array ($row['addressID']); 
        $addresstype_array = array ($row['addresstype']); 
        $addressactive_array = array ($row['active']);
        $street_array = array ($row['street']);
        $city_array = array ($row['city']);
        $town_array = array ($row['town']);
        $state_array = array ($row['state']);
        $zip_array = array ($row['zip']);
        $country_array = array ($row['country']);
        $latitude_array = array ($row['latitude']);
        $longitude_array = array ($row['longitude']);

    }   
} /* end else */

和此代码显示表单:

 <?php      
              for ($i = 0; $i < count($addressID_array); $i++) {
                  echo '<input type="text" name="street[]" id="" placeholder="street" value="';
                            if (isset ($street_array[$i])){echo $street_array[$i];}  echo '" />';
                  echo '<input type="text" name="city[]" id="city" placeholder="city" value="';
                            if (isset ($city_array[$i])){echo $city_array[$i]; } echo '" />';
                  echo '<input type="text" name="zip[]" id="zip" placeholder="postalcode" value="';
                            if (isset ($zip_array[$i])){echo $zip_array[$i]; } echo '" />'; 
                  echo '<input type="text" name="town[]" id="town" placeholder="town" value="';
                            if (isset ($town_array[$i])){echo $town_array[$i]; } echo '" />'; 
                  echo '<input type="text" name="state[]" id="state" value="';
                            if (isset ($state_array[$i])){echo $state_array[$i];} echo '" />'; 
                  echo '<input type="text" name="country[]" id="country" value="';
                            if (isset ($country_array[$i])) {echo $country_array[$i];} echo '" />'; 
                  echo '<input type="text" name="addresstype[]" id="" value="';
                            if (isset ($addresstype_array[$i])) {echo $addresstype_array[$i];} echo '" />';                       
                  echo '<input type="text" name="addressactive[]" id="" value="';
                            if (isset ($addressactive_array[$i])) {echo $addressactive_array[$i];} echo '" />';                                           echo '<input type="text" name="latitude[]" id="latitude" READONLY value="';
                            if (isset ($latitude_array[$i])) {echo $latitude_array[$i];} echo '" />';  
                  echo '<input type="text" name="longitude[]" id="longitude" READONLY value="';
                            if (isset ($longitude_array[$i])) {echo $longitude_array[$i];} echo '" /> <br>'; 
              }
              ?>

问题: 1)它只显示一个地址,即使在db中同一个客户端有2个地址。

2)我对此很陌生。我做得对吗,或者有一个最快(更少的代码)选项来做到这一点? 谢谢!!

3 个答案:

答案 0 :(得分:1)

问题出在你的while循环中:

$addressID_array = array ($row['addressID']);

每次while循环变量时,都会分配一个新数组。这些分配行应该像

一样进行更改
$addressID_array[] = $row['addressID'];

关于你的第二个问题:它并不是真正的问题,因为我们不知道你需要做出哪些要求。

答案 1 :(得分:0)

您正在通过执行此操作覆盖数组中的值

$addressID_array = array ($row['addressID']); 

而不是

$addressID_array[] = $row['addressID']; 

<强>更新 此外,迭代数据,而不是创建数据数组然后再次读取该数组将是一个好主意。使用此:

else {
$result = $stmt->get_result();
}   
// Then in display
while($row = $result->fetch_assoc()) {
    echo '<input type="text" name="street[]" id="" placeholder="street" value="';
    if (isset ($row['street'])){echo $row['street'];}  echo '" />';
}

答案 2 :(得分:0)

退房:https://en.wikipedia.org/wiki/SQL_injection

查看“十六进制转换”部分。我在那里放了一个简短的函数来执行SQL命令。当您获得信息时,它将在一个数组中。因此,如果您使用$ row来获取信息,那么它将位于$ row [0] [&lt; Fields&gt;],$ row [1] [&lt; Fields&gt;]等等。

上面的问题是 - 每次你执行“array()”时它会生成一个新数组。所以它抹去了之前你所拥有的东西。 : - )