可以用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));性能优化:确保游标字段有索引。数据量大时使用分区或优化排序。优点数据增删对已生成游标分页无影响。数据顺序稳定。注意事项游标值需要唯一。处理多用户并发时,需要确保游标生成的唯一性和分页逻辑的可复现性。
网友回复
有没有不依赖embedding向量的RAG技术?
有没有支持实时打断语音通话并后台帮你执行任何的ai模型?
开源ai大模型文件格式GGUF、MLX、Safetensors、 ONNX 有什么区别?
出海挣钱支付收款PayPal、Wise 、PingPong、Stripe如何选择?
如何实现类似google的图片隐形水印添加和识别技术?
linux上如何运行任意windows程序?
ai能写出比黑客还厉害的零日漏洞等攻击工具攻击任意软件系统工程?
js如何获取浏览器的音频上下文指纹、Canvas指纹、WebGL渲染特征?
为啥ai开始抛弃markdown文本,重新偏好html文本了?
网站有没有办法鉴别访问请求是由ai操控chrome-devtools-mcp发出的?


