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

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

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

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

PHP

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

XAMPP

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

Q&A

1回答

1204閲覧

中間テーブルをホームページ上に表示したい。

jacck

総合スコア5

MySQL

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

PHP

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

XAMPP

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

0グッド

0クリップ

投稿2021/04/22 11:08

編集2021/04/24 02:43

xamppでmysqlを操作しており、2つのテーブルを1つのテーブルに外部結合しています。
①下記コードを使用してxampp内で 結合済みの中間テーブルを表示することが出来ています。

SQL

1SELECT 2 entry.id AS 記事ID, 3 entry.title AS 記事タイトル, 4 entry.detail AS 記事内容, 5 GROUP_CONCAT(tag.name SEPARATOR ',') AS タグ名 6FROM 7 entry LEFT OUTER JOIN tag_map ON entry.id = tag_map.entry_id 8 LEFT OUTER JOIN tag ON tag.id = tag_map.tag_id 9GROUP BY entry.id 10ORDER BY entry.id;

②しかし、自作ホームページで表示しようとすると、結合前のテーブルが表示されてしまいます。

結合された中間テーブルをホームページ上に組み込む際にどういった手順が必要なのでしょうか?良ければ教えてください。。。

個人的にはホームページ側で上記のSQL文を動作させる必要があるのだろうと思っているのですが、調べてもなかなか出て来ないのでアドバイス頂きたいです。

※①xampp上で表示可能イメージ説明
※②ホームページ上でentryテーブルを選択しているが表示できないイメージ説明
引用元

SQL

1entry テーブル 2id title detail 31 PHP記事 これはPHPに関する記事です。 42 C#記事 これはC#に関する記事です。 53 PHP&MySQL記事 これはPHPとMySQLに関する記事です。 64 雑記 これは雑記です。 7 8tagテーブル(タグのマスタ) 9id name 101 Java 112 PHP 123 MySQL 134 JavaScript 145 C# 15 16tag_mapテーブル(どの記事にどのタグが紐づいているかを繋ぐテーブル) 17id entry_id tag_id (説明) 181 1 2 entry_id=1(PHP記事)に対してtag_id=2(PHP)のタグを紐づけ 192 2 5 entry_id=2(C#記事)に対してtag_id=5(C#)のタグを紐づけ 203 3 2 entry_id=3(PHP&MySQL記事)に対してtag_id=2(PHP)のタグを紐づけ 214 3 3 entry_id=3(PHP&MySQL記事)に対してtag_id=3(MySQL)のタグを紐づけ 22 23今回の作成のゴール 24記事ID 記事タイトル 記事内容          タグ名 251 PHP記事      これはPHPに関する記事です。  PHP 262 C#記事      これはC#に関する記事です。   C# 273 PHP&MySQL記事 これはPHPとMySQLに関する記事です。PHP,MySQL 284 雑記      これは雑記です。         NULL

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

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

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

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

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

wai_

2021/04/30 17:42

> 自作ホームページで表示しようとする 具体的なコードを追記してください。
guest

回答1

0

tag_mapテーブルに載っていないものは掲載しない、という前提であれば、
軸になるのはtag_mapテーブルなので、
tag_mapテーブルに対してLEFT OUTER JOINしたらいいのではないかと。

SQL

1SELECT 2 entry.id AS 記事ID, 3 entry.title AS 記事タイトル, 4 entry.detail AS 記事内容, 5 GROUP_CONCAT(tag.name SEPARATOR ',') AS タグ名 6FROM 7 tag_map LEFT OUTER JOIN entry ON tag_map.entry_id = entry.id 8 LEFT OUTER JOIN tag ON tag_map.tag_id = tag.id 9GROUP BY entry.id 10ORDER BY entry.id;

投稿2021/04/23 00:31

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

jacck

2021/04/24 02:42

回答ありがとうございます! 私の質問が下手クソで上手く質問を伝えられなかったので、画像を追加しました。 もしよければ、返答頂けると幸いです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問