可以用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));性能优化:确保游标字段有索引。数据量大时使用分区或优化排序。优点数据增删对已生成游标分页无影响。数据顺序稳定。注意事项游标值需要唯一。处理多用户并发时,需要确保游标生成的唯一性和分页逻辑的可复现性。
网友回复