跳至主要內容
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?

4563博客

全新的繁體中文 WordPress 網站
  • 首頁
  • 构建 SQL 查询语句的疑问
未分類
29 12 月 2020

构建 SQL 查询语句的疑问

构建 SQL 查询语句的疑问

資深大佬 : liquorppp 4

表 t:
字段 A 字段 B 字段 C ;
根据 C 字段进行分组,筛选出 B 字段最小的那一行,实现查询结果为不同 C 中最小的 B 的行的 A 字段集合。
有大佬有解决方案吗
大佬有話說 (14)

  • 資深大佬 : l00t

    看不懂……

  • 資深大佬 : wanv1171

    先进行分组,然后用 over 选出每组最小的 B 。然后重新根据这个结果筛选 C IN (SELECT C) AND B IN (SELECT B),然后 GROUP BY C, GROUP_CONCAT(A)

  • 資深大佬 : wanv1171

    @wanv1171 应该是 group by C, B

    第一步 over 之后应该也可以直接 group by

  • 資深大佬 : venhal

    可以了解一下开窗函数,用 row_number()over()应该就可以满足

  • 資深大佬 : venhal

    不过低版本的 mysql 好像不支持开窗函数,如果不支持的话
    select
    t1.a, t2.b, t2.c
    from
    t1
    join
    (select c, min(b) as b
    from t
    group by c) as t2 ON t1.c = t2.c AND t1.b = t2.b

  • 資深大佬 : lybcyd

    子查询吧,先用 c 分组,用 min 函数查出最小的 b 值,作为一个表 x,然后再查询大表中 b 和 c 等于 x 中 b 和 c 的记录

  • 資深大佬 : zhuangjia

    @l00t 换成实例:成绩表 t 中存储字段
    A:学生 id,
    B : 成绩,
    C:科目
    想要查询:每个科目成绩最低的同学的集合

  • 主 資深大佬 : liquorppp

    @zhuangjia 实际场景是:
    表 SKU
    uuid
    salePrice 售价
    spuId SPUuuid
    spuId 可能为空,查询出所有 SKU,如果 spuId 不为空,则取售价最低的那一条

  • 資深大佬 : l00t

    两个售价一样低的你打算怎么整。

  • 資深大佬 : weiwenhao

    select * from logs INNER JOIN (select MIN(id) as min_id FROM logs GROUP BY user_id) test on `test`.min_id = logs.id

    类似这样?

  • 資深大佬 : ZanderNg

    select t1.*
    from (select t.a,
    t.b,
    t.c,
    row_number() over(partition by t.a order by to_number(b)) as rank
    from tgxt.test_a t
    where t.c is not null) t1
    where rank = 1

  • 主 資深大佬 : liquorppp

    @weiwenhao 比较烦的是 min 内的是个价格,而不是类似 id 一样的字段

  • 主 資深大佬 : liquorppp

    @l00t 一样的可以随便取一条

  • 資深大佬 : xdwmxx

    select *
    from (select t.A,
    t.B,
    t.C,
    row_number() over(partition by t.C order by t.B) rn
    from TEST_ROW_NUMBER_OVER t)
    where t.B is not null
    and rn = 1;
    这样吗?

文章導覽

上一篇文章
下一篇文章

AD

其他操作

  • 登入
  • 訂閱網站內容的資訊提供
  • 訂閱留言的資訊提供
  • WordPress.org 台灣繁體中文

51la

4563博客

全新的繁體中文 WordPress 網站
返回頂端
本站採用 WordPress 建置 | 佈景主題採用 GretaThemes 所設計的 Memory
4563博客
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?
在這裡新增小工具