可以用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));性能优化:确保游标字段有索引。数据量大时使用分区或优化排序。优点数据增删对已生成游标分页无影响。数据顺序稳定。注意事项游标值需要唯一。处理多用户并发时,需要确保游标生成的唯一性和分页逻辑的可复现性。
网友回复
DLNA与UPnP的区别和不同?
苏超自建抢票app,通过先预约再抽签化解高并发抢票?
python如何让给电脑在局域网中伪装成电视接收手机的投屏图片视频播放?
如何结合python+js如何自己的视频编码与加密播放直播?
python如何在电脑上通过局域网将本地视频或m3u8视频投屏电视播放?
腾讯视频爱奇艺优酷vip电影电视剧视频如何通过python绕过vip收费直接观看?
有没有可免费观看全球电视台直播m3u8地址url的合集?
有没有实现观影自由的免vip影视苹果 CMS V10 API的可用url?
python如何实时检测电脑usb插入检测报警?
如何判断真人操作的鼠标移动直线轨迹与机器操作的轨迹?