2017-09-26 18 views
0

PHPとPDOを使用してMySqlバックエンドとブートストラップフロントエンドを使用してデータベースと通信するCRUDダッシュボードを作成しようとしています。私はWeb開発のノブですが、コーディングはしていません。PHP、PDO、MySqlを使用して1つのページに2つのテーブルを表示

目標は、患者の相談を記録するウェブアプリを作成することです。したがって、私のテーブル構造は、単一の「メイン」テーブルと、「コンサルト」と「プロシージャ」という名前の「メイン」テーブルとの関係を持つ2つの子テーブルです。

ダッシュボードを作成しようとしています。メインテーブルを表示し、その下に2つの子テーブルを追加します。 (後で私はそれをよりよくスタイルしますが、私はこれを動作させようとしています)。

以下は私が考えることができる最高のMWEです(より単純な解決策があればそれが大好きです)。最初の「ログブック患者」表はうまく機能し、患者の行をうまく表示します。その第2のテーブルは問題であり、特に:

$sql = "SELECT * FROM proc"; 
if($result = $pdo->query($sql)){ 
if($result->rowCount() > 0){ 

これはエラーが発生し続ける領域です。エラーは次のとおりです。

Fatal error: Uncaught Error: Call to a member function query() on null in /home/paincl5/public_html/logbook/logbook.php:110 Stack trace: #0 {main} thrown in /home/paincl5/public_html/logbook/logbook.php on line 110

ライン110のコードは私の完全なコードがある

unset($pdo); 

です:

<div class="wrapper"> 
    <div class="container-fluid"> 
     <div class="row"> 
      <div class="col-md-12"> 
       <div class="page-header clearfix"> 
        <h2 class="pull-left">Logbook Patients</h2> 
        <a href="create.php" class="btn btn-success pull-right" >Add New Patient</a> 


       </div> 
       <?php 
       // Include config file 
       require_once 'config.php'; 

       // Attempt select query execution 
       $sql = "SELECT * FROM main"; 
       if($result = $pdo->query($sql)){ 
        if($result->rowCount() > 0){ 
         echo "<div style='height:300px;overflow-y:scroll;;'>"; 
         echo "<table class='table table-bordered table-striped'>"; 
          echo "<thead>"; 
           echo "<tr>"; 
            echo "<th>Surname</th>"; 
            echo "<th>first_name</th>"; 
            echo "<th>DOB</th>"; 
            echo "<th>Hospital</th>"; 
            echo "<th>MRN</th>"; 
            echo "<th>Action</th>"; 
           echo "</tr>"; 
          echo "</thead>"; 
          echo "<tbody>"; 
          while($row = $result->fetch()){ 
           echo "<tr>"; 
            echo "<td>" . $row['Surname'] . "</td>"; 
            echo "<td>" . $row['first_name'] . "</td>"; 
            echo "<td>" . $row['DOB'] . "</td>"; 
            echo "<td>" . $row['Hospital'] . "</td>"; 
            echo "<td>" . $row['MRN'] . "</td>"; 
            echo "<td>"; 
             echo "<a href='read.php?id=". $row['id'] ."' title='View Record' data-toggle='tooltip'><span class='glyphicon glyphicon-eye-open'></span></a>"; 
             echo "<a href='update.php?id=". $row['id'] ."' title='Update Record' data-toggle='tooltip'><span class='glyphicon glyphicon-pencil'></span></a>"; 
             echo "<a href='delete.php?id=". $row['id'] ."' title='Delete Record' data-toggle='tooltip'><span class='glyphicon glyphicon-trash'></span></a>"; 
            echo "</td>"; 
           echo "</tr>"; 
          } 
          echo "</tbody>";        
         echo "</table>"; 
         echo "</div>"; 
         // Free result set 
         unset($result); 
        } else{ 
         echo "<p class='lead'><em>No records were found.</em></p>"; 
        } 
       } else{ 
        echo "ERROR: Could not able to execute $sql. " . $mysqli->error; 
       } 

       // Close connection 
       unset($pdo); 
       ?> 
      </div> 
     </div>   
    </div> 
</div> 



// Procedure Table 
<div class="wrapper"> 
    <div class="container-fluid"> 
     <div class="row"> 
      <div class="col-md-12"> 
       <div class="page-header clearfix"> 
        <h2 class="pull-left">Procedures</h2> 
        <a href="create_proc.php" class="btn btn-success pull-right" >Add New Procedure</a> 
       </div> 
       <?php 
       // Include config file 
       require_once 'config.php'; 
       // Attempt select query execution 
       $sql = "SELECT * FROM proc"; 
       if($result = $pdo->query($sql)){ 
        if($result->rowCount() > 0){ 
         echo "<div style='height:300px;overflow-y:scroll;;'>"; 
         echo "<table class='table table-bordered table-striped'>"; 
          echo "<thead>"; 
           echo "<tr>"; 
            echo "<th>Procedure Type</th>"; 
            echo "<th>Procedure Name</th>"; 
            echo "<th>Notes</th>"; 
            echo "<th>Action</th>"; 
           echo "</tr>"; 
          echo "</thead>"; 
          echo "<tbody>"; 
          while($row = $result->fetch()){ 
           echo "<tr>"; 
            echo "<td>" . $row['procedure_type'] . "</td>"; 
            echo "<td>" . $row['procedure_name'] . "</td>"; 
            echo "<td>" . $row['notes'] . "</td>"; 
            echo "<td>"; 
             echo "<a href='update.php?id=". $row['id1'] ."' title='Update Record' data-toggle='modal' data-target='#myModal' ><span class='glyphicon glyphicon-pencil'></span></a>"; 
             echo "<a href='delete.php?id=". $row['id1'] ."' title='Delete Record' data-toggle='tooltip'><span class='glyphicon glyphicon-trash'></span></a>"; 
            echo "</td>"; 
           echo "</tr>"; 
          } 
          echo "</tbody>";        
         echo "</table>"; 
         echo "</div>"; 
         // Free result set 
         unset($result); 
        } else{ 
         echo "<p class='lead'><em>No records were found.</em></p>"; 
        } 
       } else{ 
        echo "ERROR: Could not able to execute $sql. " . $mysqli->error; 
       } 

       // Close connection 
       unset($pdo); //Here occurs the error (line 110) 
       ?> 
      </div> 
     </div>   
    </div> 
</div> 

答えて

0

あなたはので、任意の後続の呼び出しをしようとしているunset($pdo)であなたの$pdo変数を破壊していますnullオブジェクトに対してメソッドを実行します。

unsetへの参照を削除してみてください。

私は$pdoオブジェクトがconfig.phpから来ていると仮定しています。 require_onceを使用しているため、最初にrequire_onceが呼び出されたときにのみ設定ファイルが含まれます。そのため、$pdoは破壊され、再作成されません。

+0

パーフェクト、私は3番目のテーブル(上記には表示されていません)にセットされていない参照のみを残し、それを修正しました。優れた。 – user2444133

関連する問題