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

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

ただいまの
回答率

89.06%

PHPで編集機能を実装していますが、変更画面に遷移できません

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 2,136

dog57

score 123

前提・実現したいこと

一覧画面(①)から変更画面(②)に遷移させようとしていますがエラーが出てうまくいきません。

イメージ説明

イメージ説明

実際の画面

イメージ説明

イメージ説明

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

Warning: PDOStatement::execute(): SQLSTATE[HY093]: Invalid parameter number: parameter was not defined in /home/vagrant/public_php/update2.php on line 27

Fatal error: Call to undefined method PDOStatement::bind_result() in /home/vagrant/public_php/update2.php on line 30

該当のソースコード

①の一覧画面 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
ini_set("display_errors", On);
error_reporting(E_ALL);

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 = $pdo->prepare('select * from country where id=?');
            if ($stmt) {
                //プレースホルダへ実際の値を設定する
                $stmt->bindParam('i', $id);
                $id = $_POST['id'];

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

                //結果変数のバインド
                $stmt->bind_result($id, $country);
                //値の取得
                $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="text" name="reason" value="<?=htmlspecialchars($reason, ENT_QUOTES, 'UTF-8')?>">
   <input type="hidden" name="id" value="<?=$id?>">
   <input type="submit" value="変更する">


</form>

</body>

  </html>

エラーの意味は理解できたのですが、自分では見つけるこができませんでした。
どうかご教授いただけたら嬉しいです。

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

php5.6,mysql  Ver 14.14

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

checkベストアンサー

+1

bind_resultはPDO/PDOStatementの関数ではないのでは?
mysqli_stmt::bind_result?

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/08/31 21:40

    PDO関数を使えば良いということでしょうか?

    キャンセル

  • 2017/08/31 21:46

    ご提示のソースがpdoを使いたがっているように見えます
    pdoとmysqliを混同されている部分が幾つか見えます。
    接続方法はどちらかに統一するよう整理されたほうがよいでしょう。

    キャンセル

  • 2017/08/31 22:09

    ありがとうございます。一度、整理してみます!

    キャンセル

0

こうじゃないですか?

$stmt->bindParam('i', $id);

$stmt->bindParam(1, $id);

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

同じタグがついた質問を見る