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

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

ただいまの
回答率

88.91%

phpの$stmt->execute(); が動かないです…

解決済

回答 3

投稿

  • 評価
  • クリップ 1
  • VIEW 305

PHPで会員登録フォームを作成しているのですが、
$stmt->execute();
実行してくれません…

phpに詳しい方教えていただけますと幸いです。

該当のソースコード

<?php 
try{
if(isset($_POST["name"])){
        $first_name = $_POST["first_name"];
        $last_name = $_POST["last_name"];
        $name = $_POST["name"];
        $e_mail = $_POST["e_mail"];
        $password = $_POST["password"];
        $telphone = $_POST["telphone"];
        $address1 = $_POST["address1"];
        $address2 = $_POST["address2"];
        $country = $_POST["country"];
        $prefecture = $_POST["prefecture"];
        $post = $_POST["post"];
        $job = $_POST["job"];
        $age = $_POST["age"];
        $sex = $_POST["sex"];
        $category = $_POST["category"];
        $dsn = 'mysql:dbname=samurai;host=localhost';
        $user = 'root';
        $password = '';

        $dbh=new PDO ($dsn,$user,$password);

        $sql = 'INSERT INTO `users` (`id`, `first_name`, `last_name`, `name`, `e-mail`,`password`,`telphone`,`address1`, `address2`, `country`, `prefecture`, `post`, `job`, `age`, `sex`, `category`,`date`) 
                VALUES (NULL, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?,current_timestamp());';

        $stmt = $dbh->prepare($sql);

        $stmt->bindParam(1,$first_name);
      $stmt->bindParam(2,$last_name);
        $stmt->bindParam(3,$name);
        $stmt->bindParam(4,$e_mail);
        $stmt->bindParam(5,$password);
        $stmt->bindParam(6,$telphone);
        $stmt->bindParam(7,$address1);
        $stmt->bindParam(8,$address2);
        $stmt->bindParam(9,$country);
        $stmt->bindParam(10,$prefecture);
        $stmt->bindParam(11,$post);
        $stmt->bindParam(12,$job);
        $stmt->bindParam(13,$age);
        $stmt->bindParam(14,$sex);
        $stmt->bindParam(15,$category);
        echo $category;
        $stmt->execute();
        echo $stmt->execute());   
}

}catch (PDOException $e){
  print('Error:'.$e->getMessage());
  die();
}
?>

試したこと

$stmt->execute();の前後をechoで挟んでみたのですが、 $stmt->execute();の上は動きましたが、下のエコーは動きませんでした…
なので$stmt->execute();が動いないのかと…

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

ここにより詳細な情報を記載してください。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • javahack

    2020/07/03 08:07

    $stmt->execute();
    echo $stmt->execute());
    カッコが一つ多いのは置いといて、これだとSQLを2回実行しているのは認識してますか?

    キャンセル

回答 3

checkベストアンサー

+2

$dbh=new PDO ($dsn,$user,$password);

の下に以下を追加してください

  $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); 

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2020/07/03 09:30

    ぱっとみ、insert文のカラムの数とデータの数が違うように思えますが?

    キャンセル

  • 2020/07/03 10:33

    ありがとうございます!無事にエラーを発見できて、解決できました!

    キャンセル

+1

あまり良い PDO の使い方ではないので、以下のページのテンプレートを参考に、修正してみると良いです。

PHP で MySQL 接続時に必要な知識(最小限版)

質問はエラーが出てないのに、登録されないってことなんですかね?
syntax error が出ているはずなんですけど?
(全角スペースが混じっています)

なので$stmt->execute();が動いないのかと…

これは認識と書き方が間違っています。
PDOStatement::execute

やるならこんな感じかなぁ。。。

$result = $stmt->execute();
var_export($result);

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2020/07/03 10:34

    早くに連絡いただいてありがとうございます!resultを使った書き方をこれから使っていきます!

    キャンセル

  • 2020/07/03 10:38

    提示のテンプレートを使用すれば、$stmt->execute() の返り値を確認する必要はないです。
    問題が発生した場合には、catch で拾うことができます。

    キャンセル

+1

既にでている内容と若干重複しますが、PHPのエラー表示をONにして、PDOExceptionを拾う設定にしてください。

このコードが全てなのでしたら、問題
が起きていても潜在させてるだけです。表にでてきません。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2020/07/03 10:33

    ありがとうございます!無事にエラーを発見できました!

    キャンセル

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

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

関連した質問

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