今天遇到一个问题,千万级别的数据表,需要全部进行遍历,如果用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因为是主键索引,能够运用索引,速度影响不大,当然,你也可以根据实际情况,应用其他字段,只要能够用上索引就可以
⬡ 规则怪谈生成器
三步选择,一键生成完整的规则怪谈场景
欢迎使用 规则怪谈生成器 (GuiZeGT) —— 专为恐怖创作者、跑团主持人和怪谈爱好者设计的在线工具。 零AI成本 · 纯模板拼接 · 无限制生成 · 免费使用
1
选择场景
2
选择氛围
3
选择难度
✦
一键生成
-
🏚️ 12个经典场景
核心
从废弃医院到深海孤岛,丰富模板即选即用 -
👻 8种恐怖风格
氛围
心理恐怖、克苏鲁、都市传说……塑造独特惊悚感 -
📜 3档规则数量
难度
从简洁到复杂,控制怪谈的细节密度与挑战性 -
⚡ 逐条浮现生成
体验
规则逐条动态呈现,营造紧张有序的阅读节奏
⚡ 或选择一个场景快速开始
🏥 废弃医院
🚢 幽灵邮轮
🌲 黑森林
🏫 午夜学校