MySQL-获取前10%数据

这里记录一个问题

在MySQL中,我们要查看前3条记录的话,是使用limit

select *from t_student order by s_id limit 3;

简单的分页也可以使用力limit来完成

select *from t_student order by s_id limit 3 offset 3;

这都比较常见,如果我们想要获取数据的前10%呢?

在SQLServer中,我们可以直接使用top 10 percent 就可以了,但在MySQL中,我们得另想办法
前10%的数据,我们得知道数据一共有多少,那我们就知道该获取多少条记录了,然后还得知道记录的行号。

    select 
        a.*,
        @row_num:=@row_num+1 as row_num 
    from 
        t_student a , (select @row_num:=0) b  
    order by 
        s_id
  • 前10%
    有了行号,我们就可以根据行号和总记录数来过滤了,我们数据少,就看前50%的
select *from (
    select 
        a.*,
        @row_num:=@row_num+1 as row_num 
    from 
        t_student a , (select @row_num:=0) b  
    order by 
        s_id
) base
where 
    base.row_num <= (@row_num*0.5)

@row_num这个变量,是按行来的,所以我们再where条件中使用的时候,他是最后1条记录的行号,及总记录数
总记录数乘以50%,就是前50%的记录数,这样,我们就获取了前X%数据,做完收工。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容