-- 列出 task_id 的所有唯一值(去重后的记录,null也是值) -- select task_id -- from Task -- group by task_id;
-- 任务总数 select count(task_id) task_num from (select task_id from Task group by task_id) tmp;
row_number
row_number 是窗口函数,语法如下:
row_number() over (partition by order by )
其中 partition by 部分可省略。
-- 在支持窗口函数的 sql 中使用 select count(case when rn=1 then task_id else null end) task_num from (select task_id , row_number() over (partition by task_id order by start_time) rn from Task) tmp;
select user_id from Test group by user_id; -- 返回1; 2
select user_id, user_type from Test group by user_id, user_type; -- 返回1, 1; 1, 2; 2, 1
select user_id, user_type from Test group by user_id; -- Hive、Oracle等会报错,mysql可以这样写。 -- 返回1, 1 或 1, 2 ; 2, 1(共两行)。只会对group by后面的字段去重,就是说最后返回的记录数等于上一段sql的记录数,即2条 -- 没有放在group by 后面但是在select中放了的字段,只会返回一条记录(好像通常是第一条,应该是没有规律的)