4

SQLite で行番号を使用する方法に関する多くの記事を読みましたが、必要な答えが得られた記事はありませんでした。このクエリを使用して行番号を選択する方法を知っています:

SELECT (SELECT COUNT() FROM table WHERE title < t.title OR (title = t.title AND id<t.id)) as rowIndex, t.title FROM table AS t ORDER BY t.title;

しかし、クエリの最後に(必要な)を追加するCOLLATE NOCASEと、結果はまったく異なります。

4

1 に答える 1

4

クエリにエラーが含まれています: エイリアス "ja" が定義されていません。

次のようにしてみてください。

SELECT 
  ( SELECT COUNT(*) + 1 
    FROM "table" 
    WHERE title < t.title OR (title = t.title AND id<t.id)
  ) as rowIndex, 
  t.title 
FROM "table" t 
ORDER BY t.title;

ただし、このサブクエリの構築はうまくスケーリングできないことに注意してください。大規模なデータセットの場合は、一時テーブルを作成し、代わりに ROWID を使用することができます (たとえば、 ここで説明されているように)。

編集: COLLATE NOCASE でテスト:

CREATE TABLE "table" (id INTEGER, title TEXT COLLATE NOCASE);

INSERT INTO "table" VALUES 
(1, "Book A"), 
(2, "Book b"), 
(3, "Book C"), 
(4, "Book B"), 
(5, "Book a"); 

クエリは次のようになります。

1|Book A
2|Book a
3|Book b
4|Book B
5|Book C

編集:

列 COLLATE NOCASE を宣言したくない場合は、ORDER BY 部分とサブクエリで COLLATE を使用していることを確認する必要があります。

SELECT 
  ( SELECT COUNT(*) + 1 
    FROM "table" 
    WHERE title < t.title COLLATE NOCASE OR (title = t.title COLLATE NOCASE  AND id<t.id)
  ) as rowIndex, 
  t.title 
FROM "table" t 
ORDER BY t.title COLLATE NOCASE;
于 2013-10-20T16:11:45.830 に答える