如图,如何获得一个用户 number 和大于等于 10 的那一条数据

image.png

现有一个数据表,需要获取同一个用户,number 累计达到大于等于 10 的那一条数据,也就是第 6 行和第 10 行。

大佬们这个 SQL 怎么写。

  • SQL
    99 引用 • 285 回帖 • 3 关注
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    1758 引用 • 11528 回帖 • 581 关注

赞助商 我要投放

被采纳的回答
  • PeterChu
    id user_id number
    1 1 1
    2 1 2
    3 1 2
    4 1 4
    5 1 7
    6 1 2
    7 2 1
    8 2 3
    9 2 8
    10 2 6
    SELECT
    	* 
    FROM
    	(
    		SELECT
    			c.id,
    			c.user_id,
    			c.number,
    			sum( c.number ) over ( PARTITION BY c.user_id rows unbounded preceding ) AS f 
    		FROM
    			user001 c 
    	) r 
    WHERE
    	r.f >= 10 
    GROUP BY
    	r.user_id 
    ORDER BY
    	r.id;
    

    结果:
    image.png

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • Blackman99

    用代码它不香吗

  • yang17762622

    我现在就是用 Java 写的,客户吗的说不行。必须要 sql......

    1 回复
  • hjljy 1 评论

    楼主要是 SQL 实现了,求一观!!! 完全没有思路

    SQL 实现参考我在楼下的回复
    CismonX
  • Blackman99

    客户为什么会参与到技术实现呢,这是什么样的客户

    1 回复
  • Eddie

    Oracle 可以用 over 函数

  • telami

    同一个用户?
    第 10 条 user_id 和第 6 条 user_id 不是不一样么

    1 回复
  • PeterChu 1 评论

    哦,我也愣了一下,他说的是累计,当用户 1 的 number 累计 =>10 时最后一个记录。

    搜 递归累加,应该可以解决
    PeterChu
  • CismonX 1 1 评论

    我在本地模拟了一下,借助窗口函数可以轻松解决。(注意,MySQL 8.0 以后的版本才支持这一特性)

    select distinct r.user_id,
                    first_value(r.number) over (partition by r.user_id) as number
    from (
             select c.user_id,
                    c.number,
                    sum(c.number) over (partition by c.user_id rows unbounded preceding) AS f
             from (
                      select 1 as user_id, 1 as number
                      union all
                      select 1 as user_id, 2 as number
                      union all
                      select 1 as user_id, 2 as number
                      union all
                      select 1 as user_id, 4 as number
                      union all
                      select 1 as user_id, 7 as number
                      union all
                      select 1 as user_id, 2 as number
                      union all
                      select 2 as user_id, 1 as number
                      union all
                      select 2 as user_id, 8 as number
                      union all
                      select 2 as user_id, 3 as number
                      union all
                      select 2 as user_id, 6 as number
                  ) c
             group by c.user_id, c.number
         ) r
    where r.f >= 10
    group by r.user_id, r.number;
    
    🤔 group by c.user_id, c.number 为什么 c.number
    PeterChu
  • PeterChu
    id user_id number
    1 1 1
    2 1 2
    3 1 2
    4 1 4
    5 1 7
    6 1 2
    7 2 1
    8 2 3
    9 2 8
    10 2 6
    SELECT
    	* 
    FROM
    	(
    		SELECT
    			c.id,
    			c.user_id,
    			c.number,
    			sum( c.number ) over ( PARTITION BY c.user_id rows unbounded preceding ) AS f 
    		FROM
    			user001 c 
    	) r 
    WHERE
    	r.f >= 10 
    GROUP BY
    	r.user_id 
    ORDER BY
    	r.id;
    

    结果:
    image.png

  • thetbw

    数据库不就是存取数据的吗,下次只直接用 SQL 写 Web 程序?

  • yang17762622

    周末这几天给忘记了,问题已经解决了,代码计算了 😂

  • yang17762622

    这个项目是一个外包,在之前的开发基础上加一下功能,然后他们那边有个 review 代码的,然后每次提交他都会讲代码风格必须不一致,然后又把我们做的功能又改一遍trollface

    1 回复
  • Blackman99

    😂

请输入回帖内容 ...