0

私は完全に困惑しています。私のページ全体のコードは以下のとおりです。

もともと、ページの上部に header.php、sidebar、topMenuBar、および mainContentShell を含め、その後に最初のクエリを実行し、次に 2 番目のクエリなどをページの残りの部分に実行しました。すべてが機能しました。私の最初のクエリは異なっていました... $_GET['stone'] の数値が 0 より大きく、select max(StoneID) より小さいことを確認しましたが、誰かが手動で StoneID を入力するとエラーが発生する可能性があります。インベントリから削除された石。$_GET 検証計画を修正し、インクルード ファイルの上に移動して、header() リダイレクトが適切に機能するようにしました。2 番目のクエリは、まったく変更されていませんが、機能しません。

Var_dump($querySN)string(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" -->
4

1 に答える 1

1

整数はStoneID = '1' のように値を引用符で囲む必要はありません。MySQL は型キャストする必要があるため、これは問題になりません。

「$result」の内容を確認していません。ブール値の場合、クエリは失敗し、mysqli_errorの出力を確認する必要があります。

于 2012-05-22T10:15:46.047 に答える