mysql 获取_MySQL-获取前10%数据

这里记录一个问题

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

select *from t_student order by s_id limit 3;

fde6f579f4d4

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

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

fde6f579f4d4

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

在SQLServer中,我们可以直接使用top 10 percent 就可以了,但在MySQL中,我们得另想办法

前10%的数据,我们得知道数据一共有多少,那我们就知道该获取多少条记录了,然后还得知道记录的行号。

记录行号

在MySQL中,获取行号,要使用变量

可以参考之前的文章:

MySQL-变量的使用

MySQL-排序

select

a.*,

@row_num:=@row_num+1 as row_num

from

t_student a , (select @row_num:=0) b

order by

s_id

fde6f579f4d4

前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)

fde6f579f4d4

@row_num这个变量,是按行来的,所以我们再where条件中使用的时候,他是最后1条记录的行号,及总记录数

总记录数乘以50%,就是前50%的记录数,这样,我们就获取了前X%数据,做完收工。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值