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(如讨论的,例如, here)。

编辑: 使用 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 回答