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

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

ただいまの
回答率

90.50%

  • MySQL

    5859questions

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

別の表から情報を参照し、条件を満たす個数を合計する方法

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 113

asakusahammu

score 2

こんにちは。SQL初心者です。

1つの表から得られた情報を元に、
別の表における条件を満たす個数を合計する処理がわかりません。

まず、gender, medal_choiceの2つの表を作成します。

CREATE TABLE `gender` (
  `user_id` int(11) NOT NULL,
  `gender` int(11) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

INSERT INTO `gender` (`user_id`, `gender`) VALUES
(100, 0),
(101, 1),
(102, 1),
(103, 0),
(104, 1);

テーブル名前:gender
(ユーザーごとの性別。0が男性、1が女性)

+---------+--------+
| user_id | gender |
+---------+--------+
|     100 |      0 |
|     101 |      1 |
|     102 |      1 |
|     103 |      0 |
|     104 |      1 |
+---------+--------+
CREATE TABLE `medal_choice` (
  `user_id` int(11) NOT NULL,
  `medal` text NOT NULL,
  `amount` int(11) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

INSERT INTO `medal_choice` (`user_id`, `medal`, `amount`) VALUES
(100, 'gold', 1),
(100, 'silver', 2),
(100, 'copper', 3),
(101, 'gold', 2),
(101, 'silver', 3),
(101, 'copper', 1),
(102, 'silver', 4),
(102, 'copper', 2),
(103, 'gold', 1),
(104, 'gold', 6),
(104, 'copper', 2);

テーブル名:medal_choice 
(各ユーザーが、gold, silver, copper3種の各メダルを何枚選んだか)

+---------+--------+--------+
| user_id | medal  | amount |
+---------+--------+--------+
|     100 | gold   |      1 |
|     100 | silver |      2 |
|     100 | copper |      3 |
|     101 | gold   |      2 |
|     101 | silver |      3 |
|     101 | copper |      1 |
|     102 | silver |      4 |
|     102 | copper |      2 |
|     103 | gold   |      1 |
|     104 | gold   |      6 |
|     104 | copper |      2 |
+---------+--------+--------+

この2つの表から、

女性ユーザーのみについて、
各ユーザー別のgoldとsilverの合計数(copperは含まない)
を、totalとして出力する

この処理を実行したいのですが、構文の組み立て方がわかりません。

<求める結果>
例えば、user_idが101のresultは、gold+silver = 2+3=5となる

(1)テーブルgenderから、user_idが1(女性)のみを抽出
(2) (1)の情報を元に、goldとsilverの合計を出力

この2処理を同時にする必要があると考えております。

皆様のお知恵を拝借したいです。宜しくお願いします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

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

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

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

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

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

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

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

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

+1

そんなに難しく考えなくても良さそうですけど、どういった点が思い付かないでしょうか。

select t1.user_id, sum(amount) as total
from  gender t1 left join medal_choice t2
      on   t1.user_id=t2.user_id 
where t1.gender=1
  and t2.medal in ('gold', 'silver')
group by t1.user_id

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/07/22 10:01

    解説は、hichonさんが書かれている内容です。

    キャンセル

  • 2018/07/22 19:24 編集

    ありがとうございます。すみません、t1,t2とは、結合テーブルの名前でしょうか?
    (SQLの基礎を丁寧になぞったら、ある程度は理解できるようになりました。急がば回れですね…)

    キャンセル

  • 2018/07/22 19:44

    t1やt2はエイリアス(別名)です。
    修飾の際、省略した名称などに用います。

    キャンセル

  • 2018/07/22 21:03

    ありがとうございます。

    キャンセル

+1

(1)テーブルgenderから、user_idが1(女性)のみを抽出
(2) (1)の情報を元に、goldとsilverの合計を出力

手続き型言語の考え方は忘れましょう。
SQLは集合(=テーブル)を操作する言語です。

(1)テーブルgenderとmedal_choiceを結合して新しいテーブルを作成
(2)新しいテーブルから(genderが1)かつ(medalがgoldまたはsilver)のレコードを取得
(3)取得したレコードのamountをuser_idごとに集計

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/07/22 10:03

    あまり内容見ないで回答しちゃいました。すみません。
    「テーブル作成する」ってところで、ちょっと違うと早とちりしてしまいました。

    キャンセル

  • 2018/07/22 19:25

    >手続き型言語の考え方は忘れましょう。
    SQLは集合(=テーブル)を操作する言語です。

    こうした基本的な考え方がよく解らず、javaのように上から順番に処理する言語だと思っていました。ありがとうございました。

    キャンセル

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

  • ただいまの回答率 90.50%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

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

  • MySQL

    5859questions

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