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

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

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

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

解決済

二つのテーブルの内容を表示するPHPプログラム

NASKA
NASKA

総合スコア10

PHP

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

3回答

0評価

0クリップ

200閲覧

投稿2022/07/07 14:42

編集2022/07/12 01:23

参考書の演習問題の解答がなく、プログラムの書き方に詰まってしまったので、質問させていただきます

PHP

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html;charset=utf-8"/> <title>Webシステム(データベースの利用例)</title> </head> <body> <h1>Webシステム</h1> <p>データベースを利用するPHPプログラムの例</p> <?php $link = mysqli_init(); // MySQLに接続する。ユーザ名とパスワードは,自分がサーバに用意したものを書く // 使用するデータベースを選択する $db = mysqli_real_connect( $link, 'localhost:8889', 'aaa', 'aaa', 'support_db', 8889); if (! $db) { exit ('MySQLには接続できません.'); } mysqli_set_charset($link, 'utf8'); // フォームに入力されているかどうか $snum = ""; if(isset($_GET['snum'])) { // 入力フォームの内容を取得する $snum = @trim($_GET['snum']); // selectコマンドを実行する $query="SELECT * FROM gakusei_t where snumber='$snum'"; //$query="SELECT * FROM gakusei_t"; $result = mysqli_query($link, $query); if (! $result) { exit ('コマンドを実行できません.'); } } ?> <form action="" method="GET"> <p>学籍番号:<input type="text" name="snum" value=" <?php echo $snum; ?> "/> <input type="submit" value="送信する"/> </p></form> <p> <?php if (isset($snum) != "" && is_numeric($snum) && mysqli_num_rows($result) == 1) { $row = mysqli_fetch_array($result); echo "<table border = \"1\">\n"; echo "<tr>\n"; echo "<th>学籍番号</th>\n"; echo "<th>氏名</th>\n"; echo "<th>出身</th>\n"; echo "<th>クラス</th>\n"; echo "</tr>\n"; echo "<tr>\n"; echo "<td align='right'>" . $row['snumber'] . "</td>\n"; echo "<td>" . $row['sname'] . "</td>\n"; echo "<td>" . $row['syusshin'] . "</td>\n"; echo "<td align='right'>" . $row['class'] . "</td>\n"; echo "</tr>\n"; echo "</table>\n"; } else { //echo ":" . $snum . ":" . isset($snum) . ":" . is_numeric($snum) . ":" . mysql_num_rows($result); } ?> </p> </body> </html>

こちらのPHPプログラムを
選択ボックスで学籍番号を選択すると、その学籍番号の学生テーブルと履修テーブルの内容を表示するPHPプログラムに変えたいです
今は

$query="SELECT * FROM gakusei_t where snumber='$snum'";

のところを

$query="SELECT * FROM gakusei_t NATURAL JOIN risyu_t WHERE gakusei_t.snumber='$snum' AND risyu_t.snumber='$snum'";

に変えて、
テーブルを表示する部分を

<?php if (isset($snum) != "" && is_numeric($snum) && mysqli_num_rows($result) == 1) { $row = mysqli_fetch_array($result); echo "<table border = \"1\">\n"; echo "<tr>\n"; echo "<th>学籍番号</th>\n"; echo "<th>氏名</th>\n"; echo "<th>出身</th>\n"; echo "<th>クラス</th>\n"; echo "<th>履修科目</th>\n"; echo "</tr>\n"; echo "<tr>\n"; echo "<td align='right'>" . $row['snumber'] . "</td>\n"; echo "<td>" . $row['sname'] . "</td>\n"; echo "<td>" . $row['syusshin'] . "</td>\n"; echo "<td align='right'>" . $row['class'] . "</td>\n"; echo "<td>\n"; foreach($row['risyu'] as $risyu){ echo $risyu['kamoku'] . "(" . $risyu['hyouka'] . ") <br\>\n"; } echo "</td>\n"; echo "</tr>\n"; echo "</table>\n"; } else { //echo ":" . $snum . ":" . isset($snum) . ":" . is_numeric($snum) . ":" . mysql_num_rows($result); } ?>

このように変えて学籍番号を入力したときに履修テーブルの内容を持ってくることができるか試したのですが、テーブルが出てきませんでした。
先程のsqlで$snumの場所に1212001と指定し、検索したものを下に載せます
イメージ説明
このように出るので、sql自体は間違っていないと思うのですが、表示の仕方がわかりません。

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

yambejp

2022/07/08 00:44

mysqli_関数はジリ貧なので自力で解決できないならはやめにpdoへの移行をおすすめします

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

PHP

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