使用行号访问sqlite中行的最快方法

时间:2013-06-26 17:14:59

标签: sqlite

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

1 个答案:

答案 0 :(得分:2)

这是LIMIT/OFFSET clauses的用途:

SELECT *
FROM Test
ORDER BY DateRecorded DESC
LIMIT 200 OFFSET 600