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 语句。所以如果我有几千行,那将是一个非常糟糕的表现。