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

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

ただいまの
回答率

88.77%

PHPからMysqlへINSERT処理を行いデータベースを追加したい。

解決済

回答 2

投稿

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

molt

score 12

前提・実現したいこと

PHPからMysqlへINSERT処理を行いデータベースを追加したい。
PHP, Mysql初心者です。過去記事見たり、その他サイトを見ましたが、関連していなそうでした。

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

PHPでMysqlへINSERT処理を行いたいのですが、データベースにデータが飛びません。
エラー表示もされず、何が間違いなのか調べてもわかりません。

該当のソースコード

//index.php

<?php
session_start();

if(!empty($_POST)){
  if($_POST['nameSei']==''){
    $error['nameSei']='blank';
  }
  if($_POST['nameMei']==''){
    $error['nameMei']='blank';
  }
  if($_POST['address1']==''){
    $error['address1']='blank';
  }
  $address1=strval($_POST['address1']);
  if(strlen($address1) != 7){
    $error['address1']='length';
  }

  if($_POST['address2']==''){
    $error['address2']='blank';
  }
  if($_POST['phone']==''){
    $error['phone']='blank';
  }

  if(empty($error)){
  $_SESSION['join']=$_POST;
  header('Location:questionForm.php');
  exit();
  }
}
?>

<!DOCTYPE html>
<html lang="ja">
  <head>
    <meta charset="utf-8">
    <title>【練習】問い合わせフォーム</title>
  </head>
  <body>
    <p><お問い合わせフォーム></p>
    <form action="" method="post">
      <dl>
        <dt>お名前</dt>
        <dd>
          【必須】姓:<input type="text", name="nameSei" size="7">
          <?php if(isset($error['nameSei']) && $error['nameSei'] == 'blank'): ?>
            <label>姓を入力してください</label><br>
          <?php endif; ?>
          【必須】名:<input type="text", name="nameMei" size="7">
          <?php if(isset($error['nameMei']) && $error['nameMei'] == 'blank'): ?>
            <label>名を入力してください</label>
          <?php endif; ?>
        </dd>
        <dt>性別</dt>
        <dd>
          <input type="radio" name="gender" value="男性" checked>男性
          <input type="radio" name="gender" value="女性">女性
        </dd>
        <dt>生年月日</dt>
        <dd>
          <select name="year">
            <?php
            $now = date("Y");
            for($i=1900; $i<=$now; $i++): ?>
            <option value="<?php echo $i;?>"><?php echo $i;?></option>
            <?php endfor;?>
          </select>年
          <select name="month">
            <?php
            $now = date("m");
            for($i=1; $i<=12; $i++): ?>
            <option value="<?php echo $i;?>"><?php echo $i;?></option>
            <?php endfor;?>
          </select>月
          <select name="day">
            <?php
            $now = date("d");
            for($i=1; $i<=31; $i++): ?>
            <option value="<?php echo $i;?>"><?php echo $i;?></option>
            <?php endfor;?>
          </select>日
        </dd>
        <dt>〒郵便番号【必須】</dt>
        <dd>
          <input type="text" name="address1">
          <?php if(isset($error['address1']) && $error['address1'] == 'blank'):?>
          <label>郵便番号を入力してください</label>
          <?php endif; ?>
          <?php if(isset($error['address1']) && $error['address1'] == 'length'):?>
          <label>郵便番号を7桁入力してください</label>
          <?php endif; ?>
        </dd>
        <dt>住所【必須】</dt>
        <dd>
          <input type="text" name="address2">
          <?php if(isset($error['address2']) && $error['address2'] = 'blank'):?>
            <label>住所を入力してください</label>
          <?php endif; ?>
        </dd>
        <dt>電話番号【必須】</dt>
        <dd>
          <input type="text" name="phone">
          <?php if(isset($error['phone']) && $error['phone'] = 'blank'):?>
            <label>電話番号を入力してください</label>
          <?php endif; ?>
        </dd>
        <dt>メールアドレス【任意】</dt>
        <dd>
          <input type="text" name="email">
        </dd>
        <dt>お問い合わせ内容</dt>
        <dd>
          <textarea name="question" rows="10" cols="50"></textarea>
        </dd>
      </dl>
      <input type="submit" value="送信">
    </form>
  </body>
</html>
//questionForm.php

<?php
session_start();

try{
  $db=new PDO('mysql:dbname=practice;host=127.0.0.1;charset=utf8','root','');
}catch (PDOException $e){
  echo 'DB接続エラー:'. $e->getMessage();
}

if(!isset($_SESSION['join'])){
  header('Location:index.php');
  exit();
}

if(!empty($_POST)){
  $statement=$db->prepare('INSERT INTO question_form SET nameSei=?, nameMei=?, gender=?, year=?, address1=?, address2=?, phone=?, email=?, question=?, created=NOW()');
  echo $ret=$statement->execute(array(
    $_SESSION['join']['nameSei'],
    $_SESSION['join']['nameMei'],
    $_SESSION['join']['gender'],
    $_SESSION['join']['year'],
    $_SESSION['join'],['address1'],
    $_SESSION['join'],['address2'],
    $_SESSION['join'],['phone'],
    $_SESSION['join'],['email'],
    $_SESSION['join'],['question'],
    $_SESSION['join'],['created'],
  ));
  unset($_SESSION['join']);

  header('Location: Receive.php');
  exit();
}
?>

<!DOCTYPE html>
<html lang="ja">
  <head>
    <meta charset="utf-8">
    <title>【練習】問い合わせフォーム</title>
  </head>
  <body>
    <p>【受け付けました】お問い合わせ内容</p>
    <form action="" method="post">
      <input type="hidden" name="action" value="submit">
       <dl>
        <dt>お名前</dt>
        <dd>
          姓:<?php echo htmlspecialchars($_SESSION['join']['nameSei'], ENT_QUOTES);?><br>
          名:<?php echo htmlspecialchars($_SESSION['join']['nameMei'], ENT_QUOTES);?>
        </dd>
        <dt>性別</dt>
        <dd>
          <?php echo htmlspecialchars($_SESSION['join']['gender'], ENT_QUOTES);?>
        </dd>
        <dt>生年月日</dt>
        <dd>
          <?php echo htmlspecialchars($_SESSION['join']['year'], ENT_QUOTES);?><?php echo htmlspecialchars($_SESSION['join']['month'], ENT_QUOTES);?><?php echo htmlspecialchars($_SESSION['join']['day'], ENT_QUOTES);?>日
        </dd>
        <dt>〒郵便番号</dt>
        <dd>
          <?php echo htmlspecialchars($_SESSION['join']['address1'], ENT_QUOTES);?>
        </dd>
        <dt>住所</dt>
        <dd>
          <?php echo htmlspecialchars($_SESSION['join']['address2'], ENT_QUOTES);?>
        </dd>
        <dt>電話番号</dt>
        <dd>
          <?php echo htmlspecialchars($_SESSION['join']['phone'], ENT_QUOTES);?>
        </dd>
        <dt>メールアドレス</dt>
        <dd>
          <?php if($_SESSION['join']['email'] == ''):?>
          <label>未入力</label>
          <?php endif; ?>
          <?php echo htmlspecialchars($_SESSION['join']['email'], ENT_QUOTES);?>
        </dd>
        <dt>お問い合わせ内容</dt>
        <dd>
          <?php echo htmlspecialchars($_SESSION['join']['question']); ?>
        </dd>
      </dl>
    </form>
  </body>
</html>

試したこと

・DBは接続できているようです。
・どうやら、questionForm.phpのif(!empty($_POST))以降が機能していないようです。
・SESSIONにデータは保存されることは確認し、quetionForm.php内のheader('Location: Receive.php');を削除すれば、問い合わせ内容が表示できます。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • m.ts10806

    2019/04/29 18:58

    >データベースを追加したい。
    表現の問題かと思いますが「データベース」は「データが格納される大きな括りそのもの」ですので
    実際にINSERTによって追加されるのは「データ」です(もともと「ベース」は「基地」の意味ですし)
    そのあたり表現調整された方が読む方も「ん?」とならなくて済むと思います。
    また、PDOException を捕捉するのであれば、接続時だけでなく、SQL送信部分も含まれた方が「根本原因」調査に役立つので、PDOException を拾う位置を調整して確認した結果を追記してください。

    キャンセル

  • molt

    2019/04/29 21:07

    下記リンクを参考に、コードを変更してみました。
    結果、変化なしです。コード間違えてましたでしょうか。

    https://teratail.com/questions/4366

    try{
    $db=new PDO('mysql:dbname=practice;host=127.0.0.1;charset=utf8','root','');
    $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); //追記
    $db->setAttribute(PDO::ATTR_EMULATE_PREPARES, false); //追記
    echo "接続OK";
    if(!empty($_POST)){
    $statement=$db->prepare('INSERT INTO question_form (nameSei, nameMei, gender, year, address1, address2, phone, email, question, created) values (?,?,?,?,?,?,?,?,?,NOW())');
    echo $ret=$statement->execute(array(
    $_SESSION['join']['nameSei'],
    $_SESSION['join']['nameMei'],
    $_SESSION['join']['gender'],
    $_SESSION['join']['year'],
    $_SESSION['join'],['address1'],
    $_SESSION['join'],['address2'],
    $_SESSION['join'],['phone'],
    $_SESSION['join'],['email'],
    $_SESSION['join'],['question'],
    $_SESSION['join'],['created'],
    ));
    }
    }catch (PDOException $e){
    echo 'DB接続エラー:'. $e->getMessage();
    }

    キャンセル

  • m.ts10806

    2019/04/29 21:18

    質問は編集できますので適宜調整いただければと。
    あと、SQLが元から変更されてるのでSQLの構文ミスなどなければ拾えないでしょう…

    キャンセル

  • molt

    2019/04/29 21:58 編集

    コメント記載内容がよくなかったですね。失礼しました。

    >PDOException を捕捉するのであれば、接続時だけでなく、SQL送信部分も含まれた方が「根本原因」調査に役立つので、PDOException を拾う位置を調整して確認した結果を追記してください。

    こちらに対して、SQL送信部分を含んだ形として、下記コードを追記しました。
    PDO('mysql:dbname=practice;host=127.0.0.1;charset=utf8','root','');
    $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); //追記
    $db->setAttribute(PDO::ATTR_EMULATE_PREPARES, false); //追記

    記載内容間違っていましたでしょうか。

    キャンセル

回答 2

check解決した方法

0

自己解決できました。
問題点は2箇所でした。

1.['join']と['created']の間に,を入力している。,を多く入力している。
2.$_SESSION['join'],['created'],に関してはPOSTしていない為、記載しない。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

uestionForm.php の if(!empty($_POST)){ のif文を下記のようにコメントアウトするとうまく動かないでしょうか。

//if(!empty($_POST)){
  $statement=$db->prepare('INSERT INTO question_form SET nameSei=?, nameMei=?, gender=?, year=?, address1=?, address2=?, phone=?, email=?, question=?, created=NOW()');
  echo $ret=$statement->execute(array(
    $_SESSION['join']['nameSei'],
    $_SESSION['join']['nameMei'],
    $_SESSION['join']['gender'],
    $_SESSION['join']['year'],
    $_SESSION['join'],['address1'],
    $_SESSION['join'],['address2'],
    $_SESSION['join'],['phone'],
    $_SESSION['join'],['email'],
    $_SESSION['join'],['question'],
    $_SESSION['join'],['created'],
  ));
  unset($_SESSION['join']);

  header('Location: Receive.php');
  exit();
//}

index.php において、下記のようにセッション変数を設定してリダイレクトしていますよね。

  $_SESSION['join']=$_POST;
  header('Location:questionForm.php');

uestionForm.php が処理すべきは $_SESSION['join'] であり、$_POST ではないと思います。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/04/29 21:50

    コメント有難うございます。うーん。。。変わらずですね泣。
    よくわかるPHPを参考にコーディングしているのですが、泥沼化しています。

    キャンセル

  • 2019/04/29 21:54

    いや、変数の値がどうなっているのかがわかれば、エラーの原因が突き止められるのではないか、という話です。ご自身でいろいろ調べてみてください。リダイレクトさせるのをやめて変数の内容を出力してみてエラーの原因を推測するくらいは自力でできるはずです。

    キャンセル

  • 2019/04/29 22:01

    コメント有難うございます。検討してみます。

    キャンセル

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

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

関連した質問

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