从mysql表中随机取出几条数据

从mysql中随机取出几条数据

方法1:

select * from table_name order by rand() limit 5
但该方法效率较差。

方法2:

①取出表的总条数;

②生成n个随机数;

③根据随机数去数据库中取数。

缺点:若随机数表示的id在数据库中不存在,则无法取出。

方法3:

SELECT *
FROM sys_user AS t1 
JOIN (SELECT ROUND(RAND() * (SELECT MAX(id) FROM sys_user)) AS id) AS t2
WHERE t1.id >= t2.id
ORDER BY t1.id asc limit 5
该方法效率较高。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值