如何一条 sql 查询出来随机 n 个公司的 n 条记录

2022-05-23 23:34:53 +08:00
 Wsdba

如图,随机查询出两个公司,各两条数据。

ps:已经问了好多人了,都说无法实现(不用存储过程和函数的情况下,单纯一条 sql),有大神能写出 sql 吗

1376 次点击
所在节点    问与答
9 条回复
512357301
2022-05-23 23:37:40 +08:00
最简单的就是用开窗函数了,其他的方法感觉都会比较麻烦
Wsdba
2022-05-23 23:49:18 +08:00
@512357301 大佬,不用函数可以实现吗,给个思路也行啊 😂
zhaogaz
2022-05-24 00:18:48 +08:00
不知道你想要的效果,不过一个思路是,新增一个 col ,入库的时候随机写入。查询的时候 生成个随机数,扔到 order
Suddoo
2022-05-24 00:35:28 +08:00
按照 dept_id 分组 ,partion by dept_id ,取每组前两个 。https://www.cnblogs.com/starzy/p/11146156.html
Maboroshii
2022-05-24 00:45:47 +08:00
为啥一定要 1 条呢。。。多查两次不就好解决了吗
fisherman0459
2022-05-24 00:55:37 +08:00
不负责瞎写🤣
select t2.*
from table t1
left join table t2 on t2.dept_name = t1.dept_name and t2.id in (select t.id from (select t3.id from table t3 where t3.dept_name = t1.dept_name order by rand() limit 1) t)
group by t1.dept_name;
lekong9
2022-05-24 08:21:15 +08:00
这不违法吗
onhao
2022-05-24 14:50:38 +08:00
我可以给你整出来 ,一个语句,不用函数
https://wuhao.pw/archives/314/
512357301
2022-06-03 12:01:18 +08:00
@Wsdba 可是函数造出来不就是为了方便的嘛。
想着不用函数就不用依赖平台了,想多了,大部分数据库的稳定性比某些小公司要高多了
比如楼上推荐的,每个公司查一次,然后 union all 拼接起来也可以,可是这也挺麻烦的,公司多了,SQL 就长了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/854833

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX