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

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

新規登録して質問してみよう
ただいま回答率
87.20%
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などのソフトウェアやライブラリモジュールなどを利用することが可能です。

受付中

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

sou_kanai
skanaim

総合スコア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などのソフトウェアやライブラリモジュールなどを利用することが可能です。

1回答

0評価

0クリップ

151閲覧

投稿2022/03/29 11:54

編集2022/03/29 21:11

こんにちは。

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>"; } ?>

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

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

まだ回答がついていません

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

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などのソフトウェアやライブラリモジュールなどを利用することが可能です。