文章目录
前言
hive执行limit语句报错,分页失败
1. 支持limit m-1, n语法的hive版本
SELECT * FROM 表名 LIMIT n; //检索前 n 个记录行
SELECT * FROM 表名 LIMIT m-1, n; //检索 m行 到 m+n行
如:
2. 不支持limit m-1, n语法,使用row_number()函数
2.1 row_number()的使用
(1)按照deptno分组,不排序
select *, row_number()over(partition by deptno) from emp;
(2)按照empno进行排序,不分组,排序列命名rownum
select * ,row_number() over (order by empno) as rownum from emp;
(3)按照empno排序,同时根据deptno进行分组
select * ,row_number() over (partition by deptno order by empno) as rownum from emp;
2.2 分页
从原表中查询第6到第10行数据
select * from (select * ,row_number() over () as rownum from emp) t where t.rownum between 6 and 10;
注:
row_number最好写一个
临时表
,不然每次都排序很耗性能
版权归原作者 但行益事莫问前程 所有, 如有侵权,请联系我们删除。