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

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

ただいまの
回答率

87.91%

MySQL 特定のカラムの重複を避けてLEFT JOINで結合したい

解決済

回答 3

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 2,872
退会済みユーザー

退会済みユーザー

MySQL 特定のカラムの重複を避けてLEFT JOINで結合したいです。

結合したいテーブルは以下の二つです。

+----+-------------+----------+-----+
| id | Jananese    | English  | age |
+----+-------------+----------+-----+
|  1 || dog      |   4 |
|  2 || monkey   |   8 |
|  3 || cat      |   1 |
|  4 || bird     |   2 |
|  5 | ライオン      | lion     |   9 |
+----+-------------+----------+-----+
+----+------------+-------------+------+
| id | animal_id  | staff_no    | sex  |
+----+------------+-------------+------+
|  1 |          1 | ueno_001    |    M |
|  2 |          2 | ueno_002    |    F |
|  3 |          1 | ueno_003    |    M |
|  4 |          3 | ueno_004    |    F |
|  5 |          3 | ueno_004    |    F |
+----+------------+-------------+------+

そして、以下のようなLEFT JOINを使って以下のような結果を求めています。

求める表示結果

+----+------------+----------+----------+
| id | staff_no   | Jananese | English  |
+----+------------+----------+----------+
|  1 | ueno_001   ||      dog |
|  2 | ueno_002   ||   monkey |
|  3 | ueno_003   ||      dog |
|  4 | ueno_004   ||      cat |
+----+------------+------- --+----------+

ですが、staff_numberの部分の重複を避けたいのですが、うまくできません。
現在のコードを出力結果は以下の通りです。

現在のコード

SELECT animal.id, staff_no, Jaopanese, English
  FROM staff
  LEFT JOIN animal
  ON staff.animal_id = animal.id ;
現在の結果

+----+------------+-------------+----------+
| id | staff_no   |   Jananese  | English  |
+----+------------+-------------+----------+
|  1 | ueno_001   ||      dog |
|  2 | ueno_002   ||   monkey |
|  3 | ueno_003   ||      dog |
|  4 | ueno_004   ||      cat |
|  5 | ueno_004   ||      cat |
+----+------------+-------------+----------+


staff_noのカラムの値の重複をさけ、ueno_004の表示を見本のように一回にしたいです。
distinctなども使ってみたのですが、うまく行きませんでした。
特定のカラムのみ重複を避けるにはどうしたら良いでしょうか?
アドバイスお願いいたします。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • YT0014

    2020/06/27 15:53

    staffテーブルで、同一staff_noで、別animal_idだった場合、どういう結果を想定されていますか?
    例えば、以下の場合とか
    | id | animal_id | staff_no | sex |
    | 6 | 1 | ueno_005 | F |
    | 7 | 2 | ueno_005 | M |

    キャンセル

  • 退会済みユーザー

    退会済みユーザー

    2020/06/27 16:03

    ありがとうございます。正直なところ、求める結果の表示にとらわれ、同一staff_noで、別animal_idの場合を想定していなかったです。
    同一staff_noで、別animal_idだった場合は、staff_noが二回表示されるようにしたいと思います。
    各ナンバーのスタッフがお世話する動物が表示され、かつ、上から順に1,2,3,4...と、一番左のIDカラムに順に番号が割りふられるイメージです、

    キャンセル

  • shun-K

    2020/06/27 16:14

    なんか不思議なテーブル設計ですね。
    animal=飼育している動物、staff=飼育員 ということでしょうか?
    飼育員「ueno_004」は男性なのですか、女性なのですか?

    キャンセル

  • 退会済みユーザー

    退会済みユーザー

    2020/06/27 16:24

    私のテーブル設計に問題がありました・・すみません。
    「ueno_004」のsexをFに統一しました。
    性別の設定はあまり意味はなく、LEFT JOINを使って、id | staff_no | Jananese | English  のカラムを結合するという意図飲みで作ったテーブルでした。そのため、設定としてよくないテーブルになってしまいました。すみません。

    キャンセル

回答 3

checkベストアンサー

+1

staffはスタッフさんのマスタテーブルかと思いきや
animalの担当テーブルみたいにも見えるのがちょっとまずい点
「ueno_004」さんは…性別がFとM両方ある…オカマかな?
animalの性別だとしたらanimalにsex列を設けるべきだし多分staffの性別なんでしょう。
animalの雄と雌で担当を区別する目的かとも思ったんですがanimalにageがあるので…(思考停止)

とりあえずSQL

SELECT min(animal.id) as id, staff_no, Jananese , English
  FROM staff
  LEFT JOIN animal
  ON staff.animal_id = animal.id ;
GROUP BY staff_no, Jananese , English

まあこうすれば求める結果にはなります。ただidの5を捨てる基準がわからない。
staffのid=5の列のanimal_idが3以外だったらどうするつもりなんでしょう。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2020/06/27 16:33

    私のテーブル設計に問題がありました・・すみません。
    「ueno_004」のsexをFに統一しました。(オカマではありません・・)
    年齢や性別の設定はあまり意味はなく、LEFT JOINを使って、id | staff_no | Jananese | English  のカラムを結合するという意図飲みで作ったテーブルでした。そのため、設定としてよくないテーブルになってしまいました。すみません。

    idの5を捨てる基準ですが、一番左のカラムのid以外が同一だった場合、重複を避けたいという意図があります。例えば、

    | 4 | ueno_004 | 猫 | cat |
    | 5 | ueno_004 | 猫 | cat |

    の場合は、 ueno_004 → 猫 が表示されれば良いので、id4と重複するid5の列は表示したくないのです。

    キャンセル

  • 2020/06/27 21:06

    であれば多分提示のSQLでいいです

    キャンセル

  • 2020/06/28 15:31

    ありがとうございます!!提示していただいたようにやったらできました!

    キャンセル

+1

提示されている仕様の場合、完全に同一な行だけ除外すれば良いので、DISTINCT を追加しましょう。

SELECT DISTINCT
  animal.id, staff_no, Jaopanese, English
  FROM staff
  LEFT JOIN animal
  ON staff.animal_id = animal.id ;


MySQL select文仕様

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2020/06/27 16:28

    ありがとうございます。DISTINCTを追加しても、表示結果は変わりませんでした。一番左側idのカラムが同一でないため、ueno_004は二回表示されてしまいます。もし、一番左のカラムにidを表示しなければ、DISTINCTは有効なのですが、左側にidは残したいため、つまづいています。

    キャンセル

  • 2020/06/27 16:35

    ご提示いただいたSQLとその結果ですが、正しい組み合わせではないのではないでしょうか?
    SQLの最初のカラムは、animal.idなので、結果は、上から、2,1,2,3,3となると思うのですが。

    キャンセル

+1

staffテーブルに問題があります
id=4,5が同じデータです、
特定のanimal_idに対しておなじstaff_noを割り当ててはだめです。
普通はstaffテーブルに対してanial_idとstaff_noの複合カラムでユニーク属性をつけて
このような重複が入力できないようにします

またstaff_no単体で重複を許すのであればsexカラムは正規化して別テーブルで管理します

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2020/06/28 15:31

    ありがとうございます。ユニーク属性をつけるなど、データの重複を避ける方法について、理解できました。

    キャンセル

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

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

関連した質問

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