Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/280.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 无法获取mysqli…调用非对象上的成员函数fetch_assoc()_Php_Mysql - Fatal编程技术网

Php 无法获取mysqli…调用非对象上的成员函数fetch_assoc()

Php 无法获取mysqli…调用非对象上的成员函数fetch_assoc(),php,mysql,Php,Mysql,我完全困惑不解。我的整个页面代码如下 最初,我将include header.php、边栏、topMenuBar和mainContentShell放在页面顶部,然后运行第一个查询,然后对页面的其余部分执行第二个查询,以此类推。一切顺利。我的第一个问题是不同的,虽然。。。我检查了$_GET['stone']号是否大于零且小于select maxStoneID,但如果有人手动输入已从库存中删除的石头的StoneID,我仍然可能会出错。我修改了我的$\u GET验证计划,并将其移到包含的文件上方,以便

我完全困惑不解。我的整个页面代码如下

最初,我将include header.php、边栏、topMenuBar和mainContentShell放在页面顶部,然后运行第一个查询,然后对页面的其余部分执行第二个查询,以此类推。一切顺利。我的第一个问题是不同的,虽然。。。我检查了$_GET['stone']号是否大于零且小于select maxStoneID,但如果有人手动输入已从库存中删除的石头的StoneID,我仍然可能会出错。我修改了我的$\u GET验证计划,并将其移到包含的文件上方,以便头重定向可以正常工作。现在,我的第二个查询将不起作用,即使它是完全不变的

Var_dump$querySN产生string53从StoneType中选择StoneName,其中StoneID='1',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包含的内容,如果它是布尔值,则查询失败,您需要查看的输出。

您是否检查了else条件右括号不存在或您没有在此处提及?