SQL初心者です。
複数のrowを一度に取りたいのですがどう書けばいいのでしょうか。
後述の(C)より効率のよい記述を探しています。
用途は掲示板で、以下のような「先頭と最近の5投稿」の取得が目的です。
環境はSQLiteです。SQLite依存で構いません。
単純には以下2クエリになりますが、
A-B間で更新されたときに過渡状態のデータが返ることを避けるため、一つに纏めたいのです。
SQLiteでは読み込みにはトランザクションが使えず、BEGIN/COMMITで囲んでブロック出来ません。
試行錯誤して一応以下のクエリは通るようですが、サブクエリが効率が悪く見えるのでもっと良い書き方を探しています。
ここで1234はスレッド名=スレッド最初の投稿Noです。
4chanのように板毎にNoが打たれており、スレ内のNoは飛び飛びになっています。
なお前側values部分もサブクエリにして先頭番号を取得する limit 1のサブクエリも書き方があれば教えてください。
(デバッグ時に使う)
これも出来ません。例えば、以下は通りません。
(A)+(B)は同時にデータも取得する為、(C)より効率がいいと考えています。
(データの順序が異なるが、簡単にカバー出来る範囲なので問題ない)
ただし(A)+(B)だと場合によっては中途半端なデータが返る時があり、これは避けたいのです。
なお初心者の為上記前提がいろいろ間違っているかもしれませんが、その辺はご指摘下さい。
BBR-MD5:CoPiPe-f5f179ef425ddb81edc49b70d35e1e1f(NEW)
BBS_COPIPE=Lv:0
PID: 46796
[0.097054 sec.]
This is Original
NGワード絞り込みスレッド★98
■ このスレッドは過去ログ倉庫に格納されています
189†Mango Mangüé ⭐ (ワッチョイ 4163-Daof)
2017/11/03(金) 19:53:55.609028ID:Xe/74+Qn0■ このスレッドは過去ログ倉庫に格納されています