【发布时间】:2013-02-01 14:52:33
【问题描述】:
我无法弄清楚为什么我的所有结果都是它返回的第一个值的重复。
此代码返回相同的 ID 和重复的格式化日期;但是,我希望它读取一个值,然后为数据库中的每个条目转换该值。这是我的代码:
<?php
include('../includes/conn.inc.php');
$stmt = $mysql->prepare("SELECT id, endDate FROM TABLE ORDER BY id");
$stmt->execute();
$stmt->bind_result($id, $endDate);
while($row = $stmt->fetch()) {
$dataRow[] = array('id'=>$id,'endDate'=> $endDate);
};
foreach($dataRow as $i) {
$newEndDate = date('Y-m-d',strtotime($endDate));
$sql = 'UPDATE TABLE SET startDate = ? WHERE id= ? ';
$stmt = $mysql->stmt_init();
if ($stmt->prepare($sql)) {
$stmt->bind_param('si',$newEndDate, $id);
$OK = $stmt->execute();}
if ($OK) {
echo $id . " " . $newEndDate . "done <br/>";
} else {
echo $stmt->error;
}
$stmt->close();
};
【问题讨论】:
-
您是否将 EndDate 从错误的格式转换?
-
要调试它,暂时忽略
foreach(可以优化,但这与您的问题无关)并查看$dataRow是否正确构造:var_dump($dataRow)之后的输出是什么环形?它在循环内输出什么? -
foreach($dataRow as $i){ print_r($i);回声“
”;这正确输出了数组