开发者社区> 问答> 正文

从mysql数据库随机读取多条不重复记录,大家是怎么做的?

SELECT * FROM `table` 
WHERE id >= (SELECT floor( RAND() * ((SELECT MAX(id) FROM `table`)-(SELECT MIN(id) FROM `table`)) + (SELECT MIN(id) FROM `table`)))  
ORDER BY id LIMIT 1;

这个也要1.2秒

本问题来自阿里云开发者社区的【11大垂直技术领域开发者社群】。 https://developer.aliyun.com/article/706511 点击链接欢迎加入感兴趣的技术领域群。

展开
收起
珍宝珠 2019-09-16 14:44:44 1133 0
1 条回答
写回答
取消 提交回答
  • 问题背景是这样,一张mysql数据表中有三个特定int字段,代表着三种不同类型的数据,然后字段1数据被抽取的概率为20%,字段2数据被抽取的概率为30%,字段3数据被抽取的概率为50%,要从这个表中随机抽10条数据,sql语句该如何描写?注意是随机取数据!!即每个字段所取得的数据的数量不固定,但总数量为10谢谢!!

    答案来源于网络,供您参考

    2019-09-18 15:17:39
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
2022 DTCC-阿里云一站式数据库上云最佳实践 立即下载
云时代的数据库技术趋势 立即下载
超大型金融机构国产数据库全面迁移成功实践 立即下载

相关镜像