我最初创建了以下查询,以便从我的数据库中返回一些结果。
$result = mysqli_query($con, "SELECT bookingId, locationName
FROM bookings
WHERE username = '$one'");
$output = array();
while($row = mysqli_fetch_assoc($result)) {
$output[]=$row;
}
print(json_encode($output));
但是,我现在想要使用预备语句,并尝试了以下内容。但它始终返回[]
。这是通过预准备语句返回行的正确方法。
$stmt = $con->prepare('SELECT bookingId,locationName
FROM bookings
WHERE username= ?');
$stmt->bind_param('s', $one);
$stmt->execute();
$stmt->bind_result($id, $loc);
$output = array();
while($row = $stmt->fetch()){
$output[] = $row;
}
$stmt->close();
print(json_encode($output));
答案 0 :(得分:4)
<强>问题:强>
与PDO
中的mysqli
不同,函数fetch()
不返回行,它只返回一个布尔值或NULL,请检查文档:
#Value Description
#TRUE Success. Data has been fetched
#FALSE Error occurred
#NULL No more rows/data exists or data truncation occurred
<强>解决方案强>
$sql = '
SELECT bookingid,
locationname
FROM bookings
WHERE username = ?
';
/* prepare statement */
if ($stmt = $con->prepare($sql)) {
$stmt->bind_param('s', $one);
$stmt->execute();
/* bind variables to prepared statement */
$stmt->bind_result($id, $loc);
$json = array();
/* fetch values */
if($stmt->fetch()) {
$json = array('id'=>$id, 'location'=>$loc);
}else{
$json = array('error'=>'no record found');
}
/* close statement */
$stmt->close();
}
/* close connection */
$con->close();
print(json_encode($json));
答案 1 :(得分:1)
您可以尝试以下操作(而不是使用bind_result()
):
$result = $stmt->get_result();
$output = array();
while ($row = $result->fetch_assoc()) {
$output[] = $row['bookingId'];
}
它基本上使你的行已经是一个数组。可能这对你来说效果更好。
如果您在while循环中没有执行任何其他操作,则可以执行RobP建议的操作,并使用fetch_all
:
mysqli_fetch_all($result, MYSQLI_ASSOC);