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

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

新規登録して質問してみよう
ただいま回答率
85.35%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PDO

PDO(PHP Data Objects)はPHPのデータベース抽象化レイヤーです。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

データベース設計

データベース設計はデータベースの論理的や物理的な部分を特定する工程です。

Q&A

解決済

1回答

791閲覧

[MySQL]POSTで送られてきた内容をDBに保存できない。

mimura00

総合スコア1

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PDO

PDO(PHP Data Objects)はPHPのデータベース抽象化レイヤーです。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

データベース設計

データベース設計はデータベースの論理的や物理的な部分を特定する工程です。

0グッド

0クリップ

投稿2021/05/03 08:31

編集2021/05/03 15:19

PHPとMySQLでゲームの掲示板を作りたい。

ここに質問の内容を詳しく書いてください。
(例)簡単なToDoリストとブログを作成した後ついに自分一人でPHPとMySQLを使い、ずっと作りたかったゲームの掲示板の作成に取り組んでいるのですがPOSTで送られてきた内容をDBに入れるところでつまづいてしまいました。
board1.phpからPOST形式でboard2.phpに送り、PDOでDBの書き込みをし、board1.phpからデータを引っ張って表示させようとしています。
特にエラーメッセージが出てくるわけではないのですが、何度送信してphp Myadminを見ても追加されません。
どこが間違っているのか、教えていただけると幸いです。

該当のソースコード

//board1.php <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>掲示板</title> </head> <body> <h2>掲示板</h2> <form action="board2.php" method="POST"> <div> <label for="model">機種 : </label> <input type="radio" name="model" value="1" checked="checked">PS4 <input type="radio" name="model" value="2">PC <input type="radio" name="model" value="3">Switch </div> <div> <label for="purpose">目的 : </label> <select name="purpose"> <option value="1">カジュアルマッチ</option> <option value="2">ランクマッチ</option> <option value="3">訓練場</option> </select> </div> <div> <label for="user_id">ID : </label> <input id="user_id" type="text" name="user_id"> </div> <div> <label for="characters">募集キャラ : </label> <select name="characters"> <option value="1">特になし</option> <option value="2">ブラッドハウンド</option> <option value="3">ジブラルタル</option> <option value="4">ライフライン</option> <option value="5">パスファインダー</option> <option value="6">レイス</option> <option value="7">バンガロール</option> <option value="8">コースティック</option> <option value="9">ミラージュ</option> <option value="10">オクタン</option> <option value="11">ワットソン</option> <option value="12">クリプト</option> <option value="13">レヴナント</option> <option value="14">ローバ</option> <option value="15">ランパート</option> <option value="16">ホライゾン</option> <option value="17">ヒューズ</option> <option value="18">ヴァルキリー</option> </select> </div> <div> <label for="rank">ランク帯 : </label> <select name="rank"> <option value="1">特になし</option> <option value="2">ブロンズ帯</option> <option value="3">シルバー帯</option> <option value="4">ゴールド帯</option> <option value="5">プラチナ帯</option> <option value="6">ダイヤ帯</option> <option value="7">マスター帯</option> <option value="8">プレデター帯</option> </select> </div> <div> <label for="level">レベル : </label> <select name="level"> <option value="1">特になし</option> <option value="2">100以上</option> <option value="3">200以上</option> <option value="4">300以上</option> <option value="5">400以上</option> <option value="6">500</option> </select> </div> <div> <label for="number_player">募集人数 : </label> <select name="number_player"> <option value="1">1人</option> <option value="2">2人</option> </select> </div> <div> <label for="message">ひと言メッセージ : </label> <textarea id="message" name="message"></textarea> </div> <input type="submit" name="btn_submit" value="送信"> </form> //board2.php <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>掲示板</title> </head> <body> <h2>投稿完了</h2> <button onclick="location.href='board1.php'">戻る</button> <?php $boards = $_POST; $dsn = 'mysql:host=localhost;dbname=keijiban;charset=utf8'; $user = '入力済み'; $pass = '入力済み'; try { $dbh = new PDO($dsn,$user,$pass,[ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, ]); } catch(PDOException $e) { echo '接続失敗'. $e->getMessage(); exit(); }; return $dbh; $sql = 'INSERT INTO board(model, purpose, user_id, characters, rank, level, number_player, message) VALUES (:model, :purpose, :user_id, :characters, :rank, :level, :number_player, :message)'; $dbh->beginTransaction(); try { $stmt = $dbh->prepare($sql); $stmt->bindValue(':model', $boards['model'], PDO::PARAM_INT); $stmt->bindValue(':purpose', $boards['purpose'], PDO::PARAM_INT); $stmt->bindValue(':user_id', $boards['user_id'], PDO::PARAM_STR); $stmt->bindValue(':characters', $boards['characters'], PDO::PARAM_INT); $stmt->bindValue(':rank', $boards['rank'], PDO::PARAM_INT); $stmt->bindValue(':level', $boards['level'], PDO::PARAM_INT); $stmt->bindValue(':number_player', $boards['number_player'], PDO::PARAM_INT); $stmt->bindValue(':message', $boards['message'], PDO::PARAM_STR); $stmt->execute(); $dbh->commit(); echo '投稿しました'; } catch(PDOException $e){ $dbh->rollBack(); exit($e); } ?>

試したこと

board1.phpからPOSTで送られてきたデータをvar_dumpで調べたら内容は出てきたので送れているのですが、そこからがわかりません。参考にした人のを見るとこれでうまくいっているのですがこちらではうまくいきません。

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

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

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

mimura00

2021/05/03 15:26

ご指摘ありがとうございます。追記しました。 ちょうどこのサイトの一番上のエラー表示を試していましたが今回は何も表示されません。別のコードを書いていた時にはきちんとエラーが表示された事はありました。 board1.phpの方にはまだselect文やif文またはswitch文で受け取った番号からテキストが表示される仕組みは作っていません。
guest

回答1

0

ベストアンサー

何度送信してphp Myadminを見ても追加されません。

PDOオブジェクトをnewしたあとで、

php

1return $dbh;

してるので、そこでスクリプトが終了してしまいますね。

投稿2021/05/04 02:03

gpsoft

総合スコア1323

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

mimura00

2021/05/04 05:30

消したらDBに保存されました! functionで囲えば消さずに済むこともわかりました! ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問