お世話になっております。PHPでMySQLを操作する会員サイトを作っています。
会員データを一覧で表示するところで、その会員から過去に問合せがあった場合、その問合せ件数を表示させたいと考えています。
イメージ的には、、、
氏名 会員ステータス 問合せ件数
佐藤一郎 Aクラス 4件
斉藤雅史 Bクラス -件
渡辺和子 Aクラス 2件
とこんな感じですが、どのようなSQL文になるのでしょうか?
会員情報の会員テーブルと、お問合せ情報を残したお問合せテーブル、そして会員ステータスなど複数のテーブルを接合した形になります。
単純に会員テーブル、お問合せテーブルと、2つのテーブルだけであれば作れたのですが、勉強不足でGROUP BY括っているため、思ったような結果が返ってこない状況になっています。(同じ氏名が並んでしまう)
複数のテーブルを接合したときどのようなSQLとなるのでしょうか?
現在、LEFT JOINで3つのテーブルを接合しており、お問合せテーブルをあわせると4つのテーブルとなります。
お忙しいところ恐縮ですが、ご教示いただければ幸いです。
よろしくお願い申し上げます。
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答2件
0
system_customerが会員テーブル
tanntoushaが担当となるスタッフのテーブル
statusが例にあるステータス名が登録されているテーブル
sql
1SHOW CREATE TABLE system_customer; 2SHOW CREATE TABLE tanntousha; 3SHOW CREATE TABLE status;
それぞれの実行結果を提示してください。
投稿2015/12/29 19:24
退会済みユーザー
総合スコア0
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2015/12/30 06:19
退会済みユーザー
2016/01/08 17:44
0
テーブルレイアウトが分からないのでアレですが
sql
1SELECT 2会員テーブル.氏名, 3会員ステータステーブル.会員ステータス, 4IFNULL(お問合せテーブル’.問合せ件数, '-') || '件' AS 問合せ件数 5FROM 6会員テーブル 7LEFT JOIN 会員ステータステーブル 8ON 会員テーブル.会員ID = 会員ステータステーブル.会員ID 9LEFT JOIN ( 10SELECT 11会員ID, COUNT(会員ID) AS 問合せ件数 12FROM 13お問合せテーブル 14GROUP BY 15会員ID 16) お問合せテーブル’ 17ON 会員テーブル.会員ID = お問合せテーブル’.会員ID
こんな感じでしょうか?
投稿2015/12/29 13:31
総合スコア736
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2015/12/29 13:58
2016/01/05 01:11
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。