teratail header banner
teratail header banner
質問するログイン新規登録
SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Q&A

2回答

743閲覧

SQLiteで日付ごとに、特定のカラムから○件ずつ取得したい

dkito

総合スコア13

SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

0グッド

0クリップ

投稿2022/04/26 06:20

編集2022/04/26 07:37

0

0

SQLiteで日付ごとに、特定のカラムから○件ずつ取得したいです。

例えば、以下のデータから、日付ごとにrankカラムから○件のデータを取得するにはどうすればいいでしょうか?

rankの小さい順に一件取得するとすれば、id:1, 3, 5, 7の行を取得したいです。
rankは必ずしも1始まりではありません。
dateとrankのペアはuniqueです。

iddaterankprice
12022-03-0111000
22022-03-0121200
32022-03-0211500
42022-03-0221600
52022-03-0311300
62022-03-0321400
72022-03-0411200
82022-03-0421300
92022-03-0431600

よろしくお願いします。

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

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

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

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

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

maisumakun

2022/04/26 06:23

「rankの小さい順から一件」のrankが1ではない可能性もある、ということで間違いないでしょうか?
dkito

2022/04/26 06:38

はい。その認識で間違いないです。 少し質問が分かりづらかったですね。 編集しておきます。
maisumakun

2022/04/26 07:28

date-rankのペアではunique、と考えて間違いないですか?
dkito

2022/04/26 07:37

はい。dateとrankのペアはuniqueです。
guest

回答2

0

ROW_NUMBERを利用されるとよいかと思います。

SQL

1SELECT * 2FROM ( 3 SELECT *, ROW_NUMBER() OVER (PARTITION BY date ORDER BY rank) rn 4 FROM T 5) A 6WHERE rn <= 1;

取得したい件数を変えたい場合は、rn <= 1の部分を調整してください。

投稿2022/04/27 03:58

neko_the_shadow

総合スコア2395

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

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

0

投稿2022/04/26 08:24

Orlofsky

総合スコア16419

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.30%

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

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

質問する

関連した質問