0

Sqlite 没有行号功能。然而,我的数据库可能有数千条记录。我需要根据日期对表进行排序(日期字段实际上是一个整数),然后返回特定范围的行。因此,如果我想要从 600 到 800 的所有行,我需要以某种方式创建一个行号并将结果限制在我想要的范围内。我不能使用 RowID 或任何自动递增的 ID 字段,因为所有数据都是随机插入的。我能得到的最接近的是:

CREATE TABLE Test (ID INTEGER, Name TEXT, DateRecorded INTEGER);

Insert Into Test (ID, Name, DateRecorded) Values (5,'fox', 400);
Insert Into Test (ID, Name, DateRecorded) Values (1,'rabbit', 100);
Insert Into Test (ID, Name, DateRecorded) Values (10,'ant', 800);
Insert Into Test (ID, Name, DateRecorded) Values (8,'deer', 300);
Insert Into Test (ID, Name, DateRecorded) Values (6,'bear', 200);

SELECT ID,
       Name,
       DateRecorded,
       (SELECT COUNT(*)
        FROM Test AS t2
        WHERE t2.DateRecorded > t1.DateRecorded) AS RowNum
FROM Test AS t1
where RowNum > 2
ORDER BY DateRecorded Desc;

这会起作用,除非它真的很难看。Select Count(*) 将导致对遇到的每一行执行该 Select 语句。所以如果我有几千行,那将是一个非常糟糕的表现。

4

1 回答 1

2

这就是LIMIT/OFFSET 子句的用途:

SELECT *
FROM Test
ORDER BY DateRecorded DESC
LIMIT 200 OFFSET 600
于 2013-06-26T20:10:52.523 回答