mysql大数据量limit问题

今天遇到一个问题,千万级别的数据表,需要全部进行遍历,如果用limit offset,count的话,无疑在翻到一定页数,也就是offset到达一定的值之后,mysql的查询速度会变得非常的慢。

$offset=0;
$count = 5000;
do {
   $sql = 'select id,uid from test_table limit ' . $offset . ',' . $count;
   $res = $obj->query($sql);
   if (empty($res)) {
       break;
   }

   // 处理$res数据start
   // 处理$res数据end

   $offset += $count;

} while(true);

为了解决这个问题,运用了一种技术方案,即,保持count, 加上带索引的有序检索条件,如:

$count = 5000;
$id = 0;
do {
   $sql = 'select id,uid from test_table where id>' . $id . ' limit ' . $count . ' order by id asc';
   $res = $obj->query($sql);
   if (empty($res)) {
       break;
   }

   // 处理$res数据start
   // 处理$res数据end
   $id = $last_id; // $last_id中最后一条记录的id
} while(true);

通过这种方式,避免了offset过大的问题,且id因为是主键索引,能够运用索引,速度影响不大,当然,你也可以根据实际情况,应用其他字段,只要能够用上索引就可以

0 0 投票数
文章评分
规则怪谈生成器 - 三步生成完整规则怪谈

⬡ 规则怪谈生成器

三步选择,一键生成完整的规则怪谈场景

欢迎使用 规则怪谈生成器 (GuiZeGT) —— 专为恐怖创作者、跑团主持人和怪谈爱好者设计的在线工具。 零AI成本 · 纯模板拼接 · 无限制生成 · 免费使用

1 选择场景
2 选择氛围
3 选择难度
一键生成
  • 🏚️ 12个经典场景 核心
    从废弃医院到深海孤岛,丰富模板即选即用
  • 👻 8种恐怖风格 氛围
    心理恐怖、克苏鲁、都市传说……塑造独特惊悚感
  • 📜 3档规则数量 难度
    从简洁到复杂,控制怪谈的细节密度与挑战性
  • ⚡ 逐条浮现生成 体验
    规则逐条动态呈现,营造紧张有序的阅读节奏
⚡ 或选择一个场景快速开始
🏥 废弃医院 🚢 幽灵邮轮 🌲 黑森林 🏫 午夜学校
订阅评论
提醒

0 评论
最新
最旧 最多投票
创世工坊 - 专业世界观构建工具

🚀 创世工坊 - 构建你的世界观

欢迎使用 创世工坊 (CreateAUniverse) —— 专为世界构建者、故事创作者和幻想宇宙缔造者设计的在线平台。将您的想象力,变成可分享的完整世界。

49,867 创作者
8,924 世界观
33,496 角色
  • 世界观构建:从地理环境到文化背景,全方位打造独一无二的架空世界。
  • 人物关系网络:可视化梳理复杂的人物关系网,让爱恨情仇一目了然。
  • 地图编辑器:强大的绘图工具,支持多种地图类型,绘制属于你的世界地图。
  • 时间线管理:梳理世界历史脉络,记录每个重要时刻,让时间线清晰有序。
  • 灵感与伏笔管理:随时记录灵感碎片,追踪每个伏笔的铺设与回收,确保逻辑严密。
滚动至顶部