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

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

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

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

PHP

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

Q&A

解決済

1回答

1059閲覧

外部キーの参照先のカラムのデータを取得したい

yuic.sk12345

総合スコア6

MySQL

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

PHP

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

0グッド

0クリップ

投稿2023/05/02 09:34

実現したいこと

ユーザーからしたら、部署用ID(1とか、2などの数字)が表示されても困ると思い、外部キーでつなげた、①のテーブルAの「部署名(総務とか経理とか)」を、一覧画面(index.php)でテーブル表示させたいです。

前提

mysql上のテーブルに作成した部署マスタの部署名を、PHPのフォーム上でプルダウンできるようにしました(ご教示ありがとうございます!)。その後、テーブルAに作った部署用IDから、部署マスタの部署IDを外部キーでつなげました。
①テーブルAには、部署用ID(1とか、2などの数字)が格納されるようにしています。
※テーブルAは、fetchallで取得できています。また、部署用ID(1とか、2などの数字)の表示でしたら、foreachで表示することもできています。

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

Warning: Trying to access array offset on value of type int in C:\xampp\htdocs\_66_iar\index.php on line 40

該当のソースコード

PHP

1■index.phpの抜粋■ 2<?php 3echo '<table class="table table table-striped">'; 4echo '<thead>'; 5echo '<tr>'; 6echo '<th>所属部署</th><th>登録日</th><th>発生日</th><th>レベル</th><th>内容</th>'; 7echo '</tr>'; 8foreach ($result as $row) { 9echo '<tr>'; 10echo '<td>'. h($row['department_id']); 11echo '</tr>'; 12} 13 14■テーブルA15ALTER TABLE `t_general` 16 ADD CONSTRAINT `department_id` FOREIGN KEY (`department_id`) REFERENCES `department` (`id`), 17 18 19■外部テーブル■ 20ALTER TABLE `department` 21ADD PRIMARY KEY (`id`); 22 2324INSERT INTO `department` (`id`, `depa`) VALUES 25(1, '総務'), 26(2, '経理'), 27・・・

試したこと

上記ソースコードの●部分に指定が足りないかと思い、「$row['department_id']['dapa']」。と入力してみましたが、取得できませんでした。

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

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

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

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

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

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

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

guest

回答1

0

ベストアンサー

joinするだけでしょう。
t_generalのdepartment_idがnullを許容しているならleft joinしていないならinner joinしてください

SQL

1create table t_general(id int primary key,department_id int null,val varchar(30)); 2INSERT INTO t_general VALUES 3(1,1, 'test1'), 4(2,2, 'test2'), 5(3,3, 'test3'), 6(4,1, 'test4'), 7(5,1, 'test5'), 8(6,null, 'test6'), 9(7,2, 'test7'); 10 11create table department(id int primary key,depa varchar(30)); 12INSERT INTO `department` (`id`, `depa`) VALUES 13(1, '総務'), 14(2, '経理'), 15(3, '営業'); 16 17alter table t_general 18ADD CONSTRAINT department_id FOREIGN KEY (department_id) REFERENCES `department` (`id`) 19on delete set null on update cascade;

としたなら

SQL

1select * from t_general as t1 2left join department as t2 3on t1.department_id=t2.id

投稿2023/05/02 10:00

yambejp

総合スコア114572

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

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

yuic.sk12345

2023/05/02 10:07

yambejp様 joinをしようするのですね。  ありがとうございます!! 初歩的ですみません。。。 ※もしかしたら、テーブル設計に失敗したかもしれません。 というのも、一覧画面(index.php)でテーブル表させたいテーブルAには、テーブルの正規化を意識しすぎて、外部キーで結合させたマスタテーブルが15個ほどある状況です。 そうすると、最悪15個のjoinをsql文の中に記述する必要がありますよね。。。 特におかしくはないものなのでしょうか? よくある仕様なのでしょうか?
yambejp

2023/05/02 10:47 編集

> マスタテーブルが15個ほどある状況です。 マスター相当のテーブルがそうであれば正規化することは間違いではありません。正規化した方がデータ管理は圧倒的に楽だと思います。 あとは、頻繁に使う基本データと、頻度の少ない詳細データをわけて管理するなど工夫は必要かもしれません。 勘違いがあるかもしれないのであえてお伝えしますが、データ管理上正規化は有効な手段であり進めるべき内容ではありますが、正規化は「高速化」とは別の考え方なので、極端な正規化は高速化と反比例することもままあります。場合によっては正規化せずにenumやset型にするとか、検索性が低くてもよいためておくだけのデータならjson型やtext型にするなど、チューニング方法はケースバイケースですね それとleft joinは負荷が高いので、マスターデータが多いのであれば原則nullを許さない管理をしてinner joinでつなぐことをおすすめします
yuic.sk12345

2023/05/02 10:43

詳しく教えて頂き、ありがとうございます!! (T_T)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問