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

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

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

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

Q&A

解決済

2回答

480閲覧

SQL 複数の条件での最大価格を取得したいが、取ってきた型番や日付が異なるものが抽出されてしまいます。

tuki43

総合スコア12

MySQL

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

0グッド

0クリップ

投稿2022/08/17 05:47

前提

下記の条件でうまく抽出できず困っています。

テーブル名:洗濯機DB
取り出したいもの :最大価格、その最大価格の型番、その最大価格の発売日、その最大価格の洗濯容量
条件 メーカー = '各種メーカー'、 洗濯容量 7kg以下、タイプ 全自動洗濯機、発売日 2017年発売以降のもの

これだと洗濯容量の最大価格ですが、型番と発売日がちがうものでした。

洗濯機DBのカラムとデータのイメージです
ID 型番 メーカー タイプ 洗濯容量 発売日 買取価格
1  D-113 AQUA 全自動洗濯機 5kg  2012-01-18 3000
2  D-114 AQUA  全自動洗濯機 5kg 2017-01-05 15000
3 D-115 AQUA 全自動洗濯機 6kg 2015-05-01 5000
4 D-116 AQUA 全自動洗濯機 7kg 2018-05-01 16000
5 D-176 AQUA 全自動洗濯機 7kg 2011-05-01 5000
6 D-117 AQUA 全自動洗濯機 6kg 2012-05-01 3000
7 D-118 AQUA 全自動洗濯機 6kg 2019-05-01 25000

取り出したいイメージ
型番 洗濯容量 発売日  買取価格
D-114 5kg 2017-01-05 15000
D-118 6kg 2019-05-01 25000
D-116 7kg 2018-01-05 16000

私のSQLでは下記のようになり、型番と発売日がDBの一番上のものになっていました。

NG
型番 洗濯容量 発売日  買取価格
D-113 5kg 2012-01-18 15000
D-115 6kg 2015-05-01 25000
D-176 7kg 2011-05-01 16000

これ以上、うまくいかないのでよろしくお願い致します。

実現したいこと

ここに実現したいことを箇条書きで書いてください。

  • ▲▲機能を動作するようにする

発生している問題・エラーメッセージ

エラーメッセージ

該当のソースコード

SQL

1SELECT MAX(買取価格), 発売日, 型番 , 洗濯容量 from 洗濯機DB WHERE メーカー = 'AQUA' AND タイプ = '全自動洗濯機' AND 洗濯容量 IN ('4kg','5kg','6kg','7kg') AND 発売日 >= '2017-01-01' GROUP BY 洗濯容量 HAVING MAX(買取価格)

試したこと

ここに問題に対して試したことを記載してください。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

sazi

2022/08/17 06:51

色々と残念な作りとなっているようですので、テーブル構造は見直しされた方が良いかと思います。 例えば、「洗濯容量 7kg以下」とありますが、容量が文字列となっているので、「10kg」は「7kg」より小さくなります。
tuki43

2022/08/17 07:02

ちょっと他のシステムでも使っているため、DB構造はそちらに合わせていますので重々承知です。
guest

回答2

0

ベストアンサー

洗濯容量ごとに最大買取価格のレコードを抽出するならこう

SQL

1create table tbl 2(ID int primary key, 3型番 varchar(20), 4メーカー varchar(20), 5タイプ varchar(20), 6洗濯容量 varchar(20), 7発売日 date, 8買取価格 int); 9 10insert into tbl values 11(1,'D-113','AQUA','全自動洗濯機','5kg','2012-01-18',3000), 12(2,'D-114','AQUA','全自動洗濯機','5kg','2017-01-05',15000), 13(3,'D-115','AQUA','全自動洗濯機','6kg','2015-05-01',5000), 14(4,'D-116','AQUA','全自動洗濯機','7kg','2018-05-01',16000), 15(5,'D-176','AQUA','全自動洗濯機','7kg','2011-05-01',5000), 16(6,'D-117','AQUA','全自動洗濯機','6kg','2012-05-01',3000), 17(7,'D-118','AQUA','全自動洗濯機','6kg','2019-05-01',25000); 18 19select * from tbl as t1 20where not exists 21(select 1 from tbl where 22洗濯容量=t1.洗濯容量 and 23買取価格>t1.買取価格) 24order by 洗濯容量;

投稿2022/08/17 06:16

yambejp

総合スコア114585

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

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

tuki43

2022/08/17 06:57 編集

ありがとうございます。 こちらの条件で試しました。 これにメーカーとタイプを条件に加えてみましたが0件と出てこなくなりました。 select 買取価格, 発売日, 洗濯容量, 質問 AS 型番 from 洗濯機DBi as t1 where not exists ( select 1 from wp_sentakuki where 洗濯容量=t1.洗濯容量 AND 買取価格>t1.買取価格) AND メーカー = 'AQUA' AND タイプ = '全自動洗濯機' AND 発売年 >= '2017-01-01' order by 洗濯容量; 指定のメーカーとタイプ(全自動洗濯機)、発売年は2017年以降で抽出したいです。 難しいです。
sazi

2022/08/17 07:36

条件を追加する場所が誤っていますよ。 select 買取価格, 発売日, 洗濯容量, 質問 AS 型番 from 洗濯機DBi as t1 where メーカー = 'AQUA' AND タイプ = '全自動洗濯機' AND 発売年 >= '2017-01-01' and not exists ( select 1 from wp_sentakuki where 洗濯容量=t1.洗濯容量 AND 買取価格>t1.買取価格 ) order by 洗濯容量
tuki43

2022/08/17 23:35

ありがとうございました。しっかりと勉強します。
guest

0

GROUP BYをかけたデータセットから、「GROUP BYをかけた列」「集計関数の結果」「列の値を必要としない式」以外の結果を取ることは、本来のSQLではできません。MySQLでは、設定によっては適当な列を返してお茶を濁します。

GROUP BYの結果を元のテーブルとJOINする」あるいは「条件を相関サブクエリで書く」などの方法を取ってください。

投稿2022/08/17 05:54

maisumakun

総合スコア145123

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問