sql - 如何从表中检索每第 N 条记录?

标签 sql mysql

查询保持不变,但偏移量发生变化。

SELECT NAME from tbl WHERE alphabet_index='A' limit 880,1;
SELECT NAME from tbl WHERE alphabet_index='A' limit 1760,1;
SELECT NAME from tbl WHERE alphabet_index='A' limit 2640,1;
....
SELECT NAME from tbl WHERE alphabet_index='A' limit 34320,1;

有没有更好的方法来执行此操作而不必运行 N 个具有不同偏移量的查询?

更新:我正在尝试构建名称范围作为向下钻取的索引。因此,如果 alphabet_index 有 50000 条记录并且我想显示 40 个范围,我正在计算 offset = total/rangeCount。我想要的最终结果是

AA...-AA...
AA...-AB...
AB...-AC...
AC...-AC...
AD...-AF...
...
...
AW...-AZ...

最佳答案

您可以像这样在单个查询中执行不同的偏移量查询

select NAME from 
   (select @row:=@row+1 as row, t.NAME from 
    tbl t, (select @row := 0) y 
    where alphabet_index='A' order by alphabet_index) z 
where row % 880 = 1;

这将通过@row 变量为每一行添加一个唯一的整数 id。然后它将通过模运算符和该变量每隔 880 选择一行。需要 order by 子句才能获得可重复的行为,否则结果实际上是随机的。

关于sql - 如何从表中检索每第 N 条记录?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1692509/

相关文章:

sql - 根据列的最大值选择行

mysql - 在 mysql 中选择 Count 的查询

sql - hive 中的分组/窗口化

mysql - 恢复 woocommerce 订单

MySQL:JOIN 表 B 但如果表 B 中没有匹配项则返回表 A

mysql - 将列转换为sql中的行

php - 为什么我的 Swift 应用程序无法连接到我的数据库?

sql - 如何评估 WHERE 子句中的输入

php - 使用两个表 JOIN 显示关系,还是使用 PHP 函数?

Mysql 变量 '@' 不适用于 'IF'