我完全困惑。我的整个页面代码如下。
最初,我在页面顶部具有include header.php,sidebar,topMenuBar和mainContentShell,在其后运行第一个查询,然后运行第二个查询,以此类推。一切正常。我的第一个查询却有所不同...我检查了$ _GET ['stone']数字是否大于零且小于选择的max(StoneID),但是如果有人手动将StoneID放入从库存中删除的石头。我修改了$ _GET验证计划,并将其移至包含的文件上方,以便header()重定向可以正常工作。现在,即使它完全不变,我的第二个查询也不起作用。
Var_dump($ querySN)产生字符串(53)“从StoneID ='1'的石头类型中选择StoneName”,而var_dump($ resultSN)产生NULL。
它指出:错误发生在第35行--- $ resultSN = $ db-> query($ querySN);
几次说明:无法获取mysqli
多次声明:不允许访问属性
并得出结论:在第36行上的非对象上调用成员函数fetch_assoc()--- $ rowSN = $ resultSN-> fetch_assoc();
有谁知道这里发生了什么以及如何解决?页面代码如下。谢谢!!!
<?php
require('./inc/config.inc.php');
$stone = (INT)$_GET['stone'];
require(MYSQL1);
$queryCk = "select StoneID from stonetypes";
$resultCk = $db->query($queryCk);
$var = array();
while ($rowCk = $resultCk->fetch_assoc()){
$var[] = $rowCk['StoneID'];
}
if(!in_array($stone, $var)) {
header('Location: beadgallery.php?type=stones');
exit;
} else {
include('inc/header.inc.php');
include('inc/sidebar.inc.php');
include('inc/topMenuBar.inc.php');
include('inc/mainContentShell.inc.php');
?>
<div id="mainContent">
<div class="center">
<?php
$querySN = "select StoneName from stonetypes where StoneID = '$stone' ";
$resultSN = $db->query($querySN);
$rowSN = $resultSN->fetch_assoc();
echo '<table id="cartDisplayTable">';
echo '<tr>';
echo '<td colspan="2">';
echo '<table id="titleTable">';
echo '<tr>';
echo '<td id="stoneTitle">';
if (isset($rowSN['StoneName'])){
echo '<h2>'.ucwords($rowSN['StoneName']).'</h2>';}
echo '</td>';
echo '</tr>';
$query = "select * from organized_inventory2 where StoneID = '$stone' ";
$result = $db->query($query);
$num_beadItems = $result->num_rows;
$justused='abc';
for ($i=0; $i < $num_beadItems; $i++) {
$row = $result->fetch_assoc();
if (!isset($row['itmphoto'])) {
echo '</table>';
echo '</td>';
echo '</tr>';
echo '<tr><td colspan="2"><hr id="cartDivider"></td></tr>';
echo '<tr>';
echo '<td id="cartImgCell">';
echo '<img src="img/nophoto.gif">';
echo '</td>';
echo '<td id="cartInfoCell">';
echo '<table id="innerTable">';
include ('inc/stoneCartInfo.inc.php');
} elseif ($row['itmphoto'] == $justused) {
echo '<tr><td colspan="2"><hr id="itemDivider"></td></tr>';
include ('inc/stoneCartInfo.inc.php');
} else {
echo '</table>';
echo '</td>';
echo '</tr>'
;
echo '<tr><td colspan="2"><hr id="cartDivider"></td></tr>'
;
echo '<tr>';
echo '<td id="cartImgCell">';
echo '<img src="img/invent/'.$row['itmphoto'].'">';
$justused = $row['itmphoto'];
echo '</td>';
echo '<td id="cartInfoCell">';
echo '<table id="innerTable">';
include ('inc/stoneCartInfo.inc.php'); }
}
echo '</table>'
;
echo '</td>';
echo '</tr>'
;
echo '</table>'
;
}
$result->free();
unset($result);
$db->close();
?>
</div> <!-- div class="center" -->
</div> <!-- div id="mainContent" -->
最佳答案
整数不要用双引号括起来,如StoneID ='1'那样,这应该不是问题,因为MySQL应该进行类型转换。
您尚未检查“ $ result”包含的内容,如果它是布尔值,则查询失败,您需要查看mysqli_error的输出。
关于php - 无法获取mysqli…在非对象上调用成员函数fetch_assoc(),我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/10695410/