可以用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));性能优化:确保游标字段有索引。数据量大时使用分区或优化排序。优点数据增删对已生成游标分页无影响。数据顺序稳定。注意事项游标值需要唯一。处理多用户并发时,需要确保游标生成的唯一性和分页逻辑的可复现性。
网友回复
如何破解绕开seedance2.0真人照片生成视频 限制?
python有哪些算法可以将视频中的每个帧图片去除指定区域水印合成新的视频?
iphone的激光雷达数据能否实时传输到three三维空间中?
豆包sora等ai视频生成大模型生成的视频水印如何去除?
python如何实现在电脑上拨号打电话给手机?
具身机器人与人形机器人区别?
nodejs如何将一个完整的js代码文件切割成不同的部分混淆后动态加载进入html运行?
为啥windows.onerror捕获js错误是这样的{"message":"Script error.","source":"","lineno":0,"colno":0,"stack":null,
2026年ai将全面接管编程?
WebMCP是干啥的?


