
こんにちは。
mysqlのselect文なのですが、LEFT OUTER JOIN した右側をgroup byし、そのなかで最大値を持つものを結び付けたいのですが、四苦八苦やってみたところ2日ほど解決できず・・・。
どなたかご教授いただけますと助かります。
テーブルなどは以下の通りです。
---tableA----(テーブル名)
user / supplier(カラム名、以下レコード)
1 / 1
1 / 2
1 / 3
2 / 1
2 / 3
---tableB---
skuno / supplier / update_at
1 / 1 / 2011-12-12
2 / 1 / 2011-12-13
3 / 1 / 2010-11-10
検索の目的は、特定のカラムuserに対応する(例えばuser = 1)supplierの値(1,2,3)を取り出し、tableBにおいて、それぞれの値に結びつくskunoのうち最新のupdate_atを持つskunoを取り出したいというものです。
上記の例の場合、希望する検索結果は以下のような想定です。
supplier / skuno
1 / 2
2 / null
3 / null
私が検討してみたsql文は以下の通りなのですが、
select supplier,skuno from tableA LEFT JOIN tableB ON tableA.supplier = tableB.supplier where tableA.user = 1 and tableB.update_at IN (select max(update_at) from tableB group by supplier) group by tableA.supplier;
この場合だと、右側がnullだとsupplierの値が表示されず、
supplier / skuno
1 / 2
となってしまいます。
select supplier,skuno from tableA LEFT JOIN tableB ON tableA.supplier = tableB.supplier where user = 1 group by supplier;
だと右側のテーブルの値が指定できず・・・
ここからどのように条件付けをしたらよいのか、お力添えをいただけますと幸いです。
よろしくお願い申し上げます。
No.1ベストアンサー
- 回答日時:
こうすれば希望する検索結果になるんじゃないでしょうか
SELECT a.supplier,b.skuno,max(update_at) from a
LEFT JOIN b ON a.supplier = b.supplier
WHERE a.user = 1 GROUP BY a.supplier;
問題はupdate_atフィールドで、「update_at IN (select max」の条件が適用される時、結合テーブルからsupplier2,3が消えるのが困るわけですよね。
まさにその通りです!
なんだかややこしい方に考えてしまっていたみたいで・・・。
お力添えの程、ありがとうございましたm(_ _)m
No.3
- 回答日時:
こうですね
select a.supplier,b.skuno
from tableA as a
left join tableB as b on b.supplier=a.supplier
and (b.supplier,b.update_at) IN (select supplier,max(update_at) as update_at from tableB group by supplier)
where user=1
No.2
- 回答日時:
こんな感じでしょうか・
MySQLの環境が無く動作確認はしていないので、文法エラーなどがあったら適宜修正してください。
select A.supplier, B.skuno
from tableA as A
left join tableB as B on (
A.supplier = B.supplier
and B.update_at IN (
select max(update_at)
from tableB as B2
where B.supplier = B2.supplier
group by supplier))
where A.userid = 1;
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
BGMを教えてほしいです!
-
テーブル名が可変の場合のクエ...
-
LIMIT で条件を満たしているの...
-
同一日に複数レコードがある場...
-
MAMP 99ドル約1.6万円 高い...
-
あってますか?SQL
-
WHERE `年月日` = '晴' OR `年...
-
SQLです教えてくださいお願いし...
-
SQLを作ったのですがうまくいき...
-
(初心者)MySQLやmaraDBで、crea...
-
SQLです教えてくださいお願いし...
-
SQLです教えてくださいお願いし...
-
SQLです教えてください。
-
SQLです教えてくださいお願いし...
-
SQLです教えてくださいお願いし...
-
SQLです教えてくださいお願いし...
-
utf8bomとutf8mb4の違いがいま...
-
「総降水量が100mm以上になる...
-
SQLで漢字名称を都道府県や市区...
-
SQLあってますか?こう?
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
count関数の値をwhere句で使用...
-
小数点以下桁数が最大の値に小...
-
結合したテーブルに名前をつけ...
-
OUTER JOIN とgroup by
-
初心者、SQLで分からない問題が...
-
MySQLで最小値
-
日本語で、likeを使うと値が正...
-
mysql について質問です
-
重複レコードを処理しない
-
同一カラム名でjoinしたところ...
-
selectの行を共通に使いたい
-
東京とその他で集計するには
-
初歩的な質問ですが、教えてく...
-
複数テーブルの集計その2
-
group by のソート
-
集計について
-
Select文を含むUpdateの記述方...
-
市区町村別の件数をカウントす...
-
( Mysql ) GROUP BY節について
-
【PHP5+MySQL5】 count(*)の値...
おすすめ情報