プログラミング

SQL select出力をリバース(反転)する

データベース操作のSQLプログラミング言語(スクリプティング言語)において、select出力をリバース(反転)する方法について紹介します。

SQL selectの出力結果を反転させたいなんて場面があります。例えば今回の例では、”クリップボードにコピーされた順で”データベースからいくつかのクリップボードの履歴を取得したい、という話です。

Bashにはtacなんていうコマンド出力結果を反転させるコマンドがあります。SQLのselectを標準出力に出してからそれをtacすることも状況によってはできますが、改行を含むフィールドがあった場合にはtacのようなコマンドは意味をなしません。

そういう処理をするならSQL側でなんとかするべきですが、一体どうやったらいいのでしょう。

このようなSQLがあります。


SELECT mText from Main
WHERE mText REGEXP "."
order by clipOrder desc
LIMIT 3 OFFSET 0

これは、以下のような出力をするとします。

hoge
fuga
foo

これを、

foo
fuga
hoge

の出力にしたい。

selectにサブクエリを渡して、それをさらに並び替えます。

SELECT q.mText
    FROM (SELECT * from Main
          WHERE mText REGEXP "."
          order by clipOrder desc
          LIMIT 3 OFFSET 0) as q
    ORDER BY q.clipOrder ASC

コメントを残す

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です