MySQL中的随机查询

1、单表随机查询

这个以前不知道,也是最近遇到的,需要从数据记录中随机取出指定条目的数据,于是上网查了一下,才知道还有这个用法,记录一下。

需要查询的表如下:
在这里插入图片描述
现在表中一共有8条数据,我只想取5条,且要求每次是随机取5条,没有固定顺序。SQL语句如下:

SELECT
	* 
FROM
USER 
ORDER BY
	rand() 
	LIMIT 5;

执行查询语句3次,结果如下:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
可以看到,3次取的结果是随机的,并没有什么固定顺序,是完全随机的。这种的话貌似效率很低,属于耗时操作,官方不建议我们使用。

2、多表随机查询

这种我尝试过,如果按照单表随机的方法进行,最后查出来的结果集是有问题的,所以对于连表查询后的结果随机,我采用的是先查询出全部结果放在List中,然后从List中随机取出指定数量的元素,这种方法虽然可以实现,但是很笨,目前暂时不知道其他的实现方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值