質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.64%

PHPで編集機能を作成していますが、変更画面に遷移しません。

受付中

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 509

dog57

score 118

前提・実現したいこと

PHPでテーブル一覧(①)を表示させた後に、変更画面(②)に遷移させたいです。

イメージ説明

イメージ説明

発生している問題・エラーメッセージ

テーブル一覧を表示させることはできました、変更画面に遷移しません。
イメージ説明

イメージ説明

 192.168.33.1:50647 [500]: /update2.php - Call to a member function prepare() on null in /home/vagrant/public_php/update2.php on line 16

テーブル一覧画面 update1.php

<?php

header("Content-type: text/html; charset=utf-8");

require_once("index_db.php");


$sql = "SELECT id, rank, nation, food, reason FROM country";
$statement = $pdo->query($sql);

// 結果の取得
$country = array();
foreach ($statement as $row) {
    $country[] = $row;
}
var_dump($country);

// データベース切断
$pdo = null;

?>

<!DOCTYPE html>
<html>
<head>
<title>国一覧</title>
</head>
<body>
<h1>国一覧</h1>

<table border='1'>
<tr><td>id</td><td>順位</td><td>国名</td><td>食べたい食べ物</td><td>理由</td></tr>

<?php
foreach($country as $row){
 ?>



 <tr>
 <td><?=$row['id']?></td>
 <td><?=htmlspecialchars($row['rank'], ENT_QUOTES, 'UTF-8')?></td>
 <td><?=htmlspecialchars($row['nation'], ENT_QUOTES, 'UTF-8')?></td>
 <td><?=htmlspecialchars($row['food'], ENT_QUOTES, 'UTF-8')?></td>
 <td><?=htmlspecialchars($row['reason'], ENT_QUOTES, 'UTF-8')?></td>
 <td>
   <form action="update2.php" method="post">
   <input type="submit" value="編集">
   <input type="hidden" name="id" value="<?=$row['id']?>">
   <input type="hidden" name="rank" value="<?=$row['rank']?>">
   <input type="hidden" name="nation" value="<?=$row['nation']?>">
   <input type="hidden" name="food" value="<?=$row['food']?>">
   <input type="hidden" name="reason" value="<?=$row['reason']?>">
   </form>
 </td>
</tr>



 <?php
 }
 ?>

</table>

</body>
</html>

変更画面 update2.php

<?php

header("content-type: text/html; charset=utf-8");
require_once("index_db.php");


try {

    if(empty($_POST)) {
        echo "<a href='update1.php'>update1.php</a>←こちらのページからどうぞ";
        exit();
    }else {
        if (!isset($_POST['id'])  || !is_numeric($_POST['id']) ){

            echo "idエラー";
            exit();
        }else {
            //プリペアドスタートメント
            $stmt = $dbh->prepare('select * from country where id=?');
            if ($stmt) {
                //プレースホルダへ実際の値を設定する
                $stmt->bind_param('i',$id);
                $id = $_POST['id'];

                //クエリの実行
                $stmt->execute();

                //結果変数のバインド
                $stmt->bind_result($id);
                //値の取得
                $stmt->fetch();

                //ステートメント切断
                $stmt = null;
            }else {
                echo $mysqli->errno . $mysqli->error;
            }
        }
    }
} catch (Exception $e) {
    echo '捕捉した例外: ',  $e->getMessage(), "\n";
}


?>

<iDOCTYPE html>
  <!DOCTYPE html>
  <html>

<head>
  <title>変更画面</title>
</head>

<body>

<p>変更してください</p>
<form action="update3.php">

   <input type="text" name="rank" value="<htmlspecialchars($rank, ENT_QUOTES, 'UTF-8')?>">
   <input type="text" name="nation" value="<htmlspecialchars($nation, ENT_QUOTES, 'UTF-8')?>">
   <input type="text" name="food" value="<htmlspecialchars($food, ENT_QUOTES, 'UTF-8')?>">
   <input type="submit" value="変更する">


</form>

</body>

  </html>

補足情報(言語/FW/ツール等のバージョンなど)

PHP 5.6.30,mysql Ver 14.14,vagrant

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • m.ts10806

    2017/08/29 21:53 編集

    前の質問からほとんど進んでないように思います。主題が解決していないのであれば前の質問で解決するまでやりとりすべきと思います。このままでは丸投げと変わりません。エラーメッセージを調べて対応する癖をつけないとキリがありませんよ。PHPは親切なエラーを出してくれていて原因とかけ離れていることは少ない言語なので、まずはGoogle検索にかけるかGoogle翻訳にかけましょう。

    キャンセル

  • m.ts10806

    2017/08/29 22:04

    https://teratail.com/help/question-tips#questionTips1-2 も参考にしてください。

    キャンセル

回答 1

0

update1.php

$statement = $pdo->query($sql);

update2.php

$stmt = $dbh->prepare('select * from country where id=?');

で、$pdoと$dbh、違うの使ってますが問題ないですか?

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.64%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる