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

image.png

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

大佬们这个 SQL 怎么写。

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

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

    1732 引用 • 11428 回帖 • 583 关注

赞助商 我要投放

被采纳的回答
  • 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

13 回帖
请输入回帖内容 ...
  • hjljy 1 评论

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

    SQL 实现参考我在楼下的回复
    CismonX
  • 其他回帖
  • thetbw

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

  • 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

  • yang17762622

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

    1 回复
  • 查看更多回帖