V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
Wsdba
V2EX  ›  问与答

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

  •  
  •   Wsdba · 2022-05-23 23:34:53 +08:00 · 1315 次点击
    这是一个创建于 896 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

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

    9 条回复    2022-06-03 12:01:18 +08:00
    512357301
        1
    512357301  
       2022-05-23 23:37:40 +08:00 via Android
    最简单的就是用开窗函数了,其他的方法感觉都会比较麻烦
    Wsdba
        2
    Wsdba  
    OP
       2022-05-23 23:49:18 +08:00
    @512357301 大佬,不用函数可以实现吗,给个思路也行啊 😂
    zhaogaz
        3
    zhaogaz  
       2022-05-24 00:18:48 +08:00
    不知道你想要的效果,不过一个思路是,新增一个 col ,入库的时候随机写入。查询的时候 生成个随机数,扔到 order
    Suddoo
        4
    Suddoo  
       2022-05-24 00:35:28 +08:00
    按照 dept_id 分组 ,partion by dept_id ,取每组前两个 。https://www.cnblogs.com/starzy/p/11146156.html
    Maboroshii
        5
    Maboroshii  
       2022-05-24 00:45:47 +08:00 via Android
    为啥一定要 1 条呢。。。多查两次不就好解决了吗
    fisherman0459
        6
    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
        7
    lekong9  
       2022-05-24 08:21:15 +08:00 via Android
    这不违法吗
    onhao
        8
    onhao  
       2022-05-24 14:50:38 +08:00
    我可以给你整出来 ,一个语句,不用函数
    https://wuhao.pw/archives/314/
    512357301
        9
    512357301  
       2022-06-03 12:01:18 +08:00 via Android
    @Wsdba 可是函数造出来不就是为了方便的嘛。
    想着不用函数就不用依赖平台了,想多了,大部分数据库的稳定性比某些小公司要高多了
    比如楼上推荐的,每个公司查一次,然后 union all 拼接起来也可以,可是这也挺麻烦的,公司多了,SQL 就长了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   987 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 22:11 · PVG 06:11 · LAX 14:11 · JFK 17:11
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.