+
82
-

回答

可以用create时间戳作为查询的游标

数据准备

假设有一个 articles 表,结构如下:

CREATE TABLE articles (
    id INT PRIMARY KEY AUTO_INCREMENT,
    title VARCHAR(255),
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
插入测试数据
INSERT INTO articles (title) VALUES 
('Article 1'), ('Article 2'), ('Article 3'),
('Article 4'), ('Article 5'), ('Article 6');
游标分页查询使用 created_at 或类似字段作为游标。根据游标和分页大小动态查询。第一次查询(第一页)

假设分页大小为 3 条:

SELECT * 
FROM articles
ORDER BY created_at ASC
LIMIT 3;

结果将返回第一个游标。

第二次查询(基于游标)

假设上一次结果的最后一条记录的 created_at 为 '2024-11-18 10:00:00',可以用此值作为游标:

SELECT * 
FROM articles
WHERE created_at > '2024-11-18 10:00:00'
ORDER BY created_at ASC
LIMIT 3;
插入新数据时处理

新插入的数据会拥有更晚的 created_at 值,不会影响已固定的游标分页。新游标会自动分配到新数据。

改进建议游标生成:为了不直接依赖时间戳,可以生成全局唯一的 cursor 字段,作为每条记录的标识。示例:
ALTER TABLE articles ADD cursor VARCHAR(255) UNIQUE;
UPDATE articles SET cursor = MD5(CONCAT(id, created_at));
性能优化:确保游标字段有索引。数据量大时使用分区或优化排序。优点数据增删对已生成游标分页无影响。数据顺序稳定。注意事项游标值需要唯一。处理多用户并发时,需要确保游标生成的唯一性和分页逻辑的可复现性。

网友回复

我知道答案,我要回答