Sqlite没有行号功能。然而,我的数据库可能有数千条记录。我需要根据日期(日期字段实际上是一个INTEGER)对表进行排序,然后返回特定的行范围。因此,如果我想要所有行从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语句。因此,如果我有几千行,那将是一个非常糟糕的表现。
答案 0 :(得分:2)
这是LIMIT/OFFSET clauses的用途:
SELECT *
FROM Test
ORDER BY DateRecorded DESC
LIMIT 200 OFFSET 600