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

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

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

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

MySQL

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

PHP

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

Bootstrap

BootstrapはウェブサイトデザインやUIのWebアプリケーションを素早く 作成する可能なCSSフレームワークです。 Twitter風のデザインを作成することができます。

XAMPP

XAMPP(ザンプ)は、ウェブアプリケーションの実行に必要なフリーソフトウェアをパッケージングしたApacheディストリビューションです。 XAMPPひとつインストールするだけで、Apache、MySQL、PHP、Perlなどのソフトウェアと、 phpMyAdminなどの管理ツール、SQLiteなどのソフトウェアやライブラリモジュールなどを利用することが可能です。

Q&A

1回答

313閲覧

phpとmySQLでの検索・追加システムで、フォームからのデータベースへ追加した際の同一ページでの出力表示

sou_kanai

総合スコア0

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

MySQL

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

PHP

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

Bootstrap

BootstrapはウェブサイトデザインやUIのWebアプリケーションを素早く 作成する可能なCSSフレームワークです。 Twitter風のデザインを作成することができます。

XAMPP

XAMPP(ザンプ)は、ウェブアプリケーションの実行に必要なフリーソフトウェアをパッケージングしたApacheディストリビューションです。 XAMPPひとつインストールするだけで、Apache、MySQL、PHP、Perlなどのソフトウェアと、 phpMyAdminなどの管理ツール、SQLiteなどのソフトウェアやライブラリモジュールなどを利用することが可能です。

0グッド

0クリップ

投稿2022/03/29 11:54

編集2022/03/29 11:57

こんにちは。

PHPとmySQLで検索システムとデータベースへの追加システムを作っています。
コードが検索システムが書かれているコードとINSERT文があるコードで2つに分かれており、INSERT文があるphp(add.php)を検索システムがあるphp(main.php)の下部(追加ボタンの下)に反映させたいです。

main.phpの109行目の<form action="add.php" method="post"><form action="" method="post">に変更し、132行目以降にadd.php内の記述を行い、59行目(if ($_POST) { try {~ の部分)から記述されているphp内のadd.phpと重複する変数を削除し纏めてもの59行目の部分でエラーが出てしまいます。

main.php↓

<!DOCTYPE html> <html> <head> <html lang="ja"> <meta charset="utf-8"> <title>用語検索</title> <!-- Bootstrap CSS --> <meta name="viewport" content="width=device-width,initial-scale=1"> <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" integrity="sha384-MCw98/SFnGE8fJT3GXwEOngsV7Zt27NXFoaoApmYm81iuXoPkFOJwJ8ERdknLPMO" crossorigin="anonymous"> <link rel="shortcut icon" href="img\favicon.png"> <style> body { background: #f3f3f3; font-family: 'Noto Sans JP', sans-serif; } </style> </head> <body> <center> <div class="container mt-5 pt-5"> <div class="row"> <div class="col-md-6 offset-md-3"> <h3 class="mb-5 text-center">用語検索</h3> </div> </div> </div> <div class="mb-5"> <form action="" method="POST"> <div class="form-group col-5"> <input type="text" name="keyword" placeholder="単語を入力して下さい" class="form-control"/> </div> <div class="form-group col-5"> <input type="submit" value="検索" class="form-control"/> </div> </form> </div> <div class="col-xs-6 col-xs-offset-3"> <table class="table"> <thead> <tr> <th>用語</th> <th>意味</th> <th>種類</th> <th>使用例</th> </tr> </thead> <tbody> <tr> <?php $dsn = 'mysql:host=localhost;dbname=*****'; $username = 'root'; $password = '****'; if ($_POST) { try { $dbh = new PDO($dsn, $username, $password); $searchWord = $_POST['keyword']; if($searchWord==""){ echo "<td>用語を入力して下さい</td>"; } else{ $sql ="select * from lwolist where wordorigin like '".$searchWord."%'"; $sth = $dbh->prepare($sql); $sth->execute(); $result = $sth->fetchAll(); if($result){ foreach ($result as $row) { echo "<td>".$row['wordorigin']."</td><td>".$row['wordmeaning']."</td><td>".$row['wordtype']."</td><td>".$row['wordexample']."</td>"; } } else{ echo "<td>一致する用語が有りませんでした</td>"; } } }catch (PDOException $e) { echo "<p>Failed : " . $e->getMessage()."</p>"; exit(); } } ?> </tr> </tbody> </table> <div class="container mt-5 pt-5"> <div class="row"> <div class="col-md-6 offset-md-3"> <h3 class="mb-5 text-center">用語追加</h3> </div> </div> </div> <form action="add.php" method="post"> <div class="form-group col-5"> <input type="text" name="insertedword" placeholder="用語を半角英字で入力して下さい" class="form-control"/> </div> <div class="form-group col-5"> <input type="text" name="insertedmeaning" placeholder="用語の意味を入力して下さい" class="form-control"/> </div> <div class="form-group col-5"> <select name="insertedtype" class="form-control">      <option disabled selected value="用語の種類を選択して下さい">用語の種類を選択して下さい</option> <option value="種類1">種類1</option> <option value="種類2">種類2</option> <option value="種類3">種類3</option> <option value="種類4">種類4</option> </select> </div> <div class="form-group col-5"> <input type="text" name="insertedexample" placeholder="使用例を入力して下さい" class="form-control"/> </div> <div class="form-group col-5">    <input type="submit" value="追加" class="form-control"/> </div> </form> <?php add.phpのメッセージ出力結果を反映させたい場所です。 「3種の入力フォームと1種のドロップダウンリストから送信されてきた値が空でない場合にそれぞれの値をmySQLのデータベースに追加し、メッセージ(add.phpの24行目と33行目)を出力する」です。 ?> <br> <h7>Copyright © 2022 user</h7> <br> </center> </body> </html>

add.php↓

<?php if($_POST['insertedword'] != "" && $_POST['insertedmeaning'] != "" && $_POST['insertedtype'] != "" && $_POST['insertedexample'] != "") { try { //DB名、ユーザー名、パスワード $dsn = 'mysql:dbname=*****;host=*****'; $user = 'root'; $password = '****'; $insertedWord = $_POST['insertedword']; $insertedMeaning = $_POST['insertedmeaning']; $insertedType = $_POST['insertedtype']; $insertedExample = $_POST['insertedexample']; $PDO = new PDO($dsn, $user, $password); //MySQLのデータベースに接続 $PDO->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); //PDOのエラーレポートを表示 $sql = "INSERT INTO lwolist (wordorigin, wordmeaning, wordtype, wordexample) VALUES (:wordorigin, :wordmeaning, :wordtype, :wordexample)"; $stmt = $PDO->prepare($sql); $params = array(':wordorigin' => $insertedWord, ':wordmeaning' => $insertedMeaning, ':wordtype' => $insertedType, ':wordexample' => $insertedExample); $stmt->execute($params); echo "<center>用語「".$insertedWord."」に「".$insertedMeaning."」という意味の「".$insertedType."」が使用例「".$insertedExample."」としてデータベースに追加されました!</center>"; } catch (PDOException $e) { exit('データベースに接続できませんでした。' . $e->getMessage()); } } else { echo "<center>入力エラーが有りました</center>"; } ?>

お手数お掛けして申し訳ないのですがもしお時間が御座いましたらご教授宜しくお願い致します。

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

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

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

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

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

guest

回答1

0

とりあえずtry-catchするならエラーモードの設定をしてください

PHP

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

prepareの使用方法もおかしいです

投稿2022/03/29 12:06

yambejp

総合スコア114968

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

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

sou_kanai

2022/03/29 12:11

yambejp様 有り難う御座います。試してみます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問