Wsdba
V2EX  ›  问与答

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

  •  
  •   Wsdba · May 23, 2022 · 2081 views
    This topic created in 1465 days ago, the information mentioned may be changed or developed.

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

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

    9 replies    2022-06-03 12:01:18 +08:00
    512357301
        1
    512357301  
       May 23, 2022 via Android
    最简单的就是用开窗函数了,其他的方法感觉都会比较麻烦
    Wsdba
        2
    Wsdba  
    OP
       May 23, 2022
    @512357301 大佬,不用函数可以实现吗,给个思路也行啊 😂
    zhaogaz
        3
    zhaogaz  
       May 24, 2022
    不知道你想要的效果,不过一个思路是,新增一个 col ,入库的时候随机写入。查询的时候 生成个随机数,扔到 order
    Suddoo
        4
    Suddoo  
       May 24, 2022
    按照 dept_id 分组 ,partion by dept_id ,取每组前两个 。https://www.cnblogs.com/starzy/p/11146156.html
    Maboroshii
        5
    Maboroshii  
       May 24, 2022 via Android
    为啥一定要 1 条呢。。。多查两次不就好解决了吗
    fisherman0459
        6
    fisherman0459  
       May 24, 2022
    不负责瞎写🤣
    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  
       May 24, 2022 via Android
    这不违法吗
    onhao
        8
    onhao  
       May 24, 2022
    我可以给你整出来 ,一个语句,不用函数
    https://wuhao.pw/archives/314/
    512357301
        9
    512357301  
       Jun 3, 2022 via Android
    @Wsdba 可是函数造出来不就是为了方便的嘛。
    想着不用函数就不用依赖平台了,想多了,大部分数据库的稳定性比某些小公司要高多了
    比如楼上推荐的,每个公司查一次,然后 union all 拼接起来也可以,可是这也挺麻烦的,公司多了,SQL 就长了
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   5313 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 38ms · UTC 08:07 · PVG 16:07 · LAX 01:07 · JFK 04:07
    ♥ Do have faith in what you're doing.