首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL,获取列的最大id

SQL,获取列的最大id
EN

Stack Overflow用户
提问于 2015-07-14 22:28:37
回答 2查看 27.3K关注 0票数 2

我已经在MS SQL Server Management Studio中获得了此表

代码语言:javascript
复制
+------+-----------+--------
| id   | client id | bla bla blaaaa
+------+-----------+--------
|    1 |   1       | .......
|    2 |   2       | .......
|    3 |   3       | .......
|    4 |   8       | .......
|    5 |   9       | .......
|    6 |   15      | .......
|    7 |   1       | .......
|    8 |   16      | .......
|    9 |   2       | .......
|   10 |   9       | .......
|   12 |   12      | .......
+------+-----------+--------

我需要获取唯一的客户端id,最大值为id,如下所示

代码语言:javascript
复制
+------+-----------+--------
| id   | client id | bla bla blaaaa
+------+-----------+--------
|    3 |   3       | .......
|    4 |   8       | .......
|    6 |   15      | .......
|    7 |   1       | .......
|    8 |   16      | .......
|    9 |   2       | .......
|   10 |   9       | .......
|   12 |   12      | .......
+------+-----------+--------

我试过这段代码,但它不能很好地工作。有人能帮我吗?

代码语言:javascript
复制
SELECT *
FROM   table AS one 
INNER JOIN table AS two
   ON one.[client id] = two.[client id]
   WHERE one.[id] > two.[id]
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-07-14 22:31:59

代码语言:javascript
复制
SELECT max(id), client_id, blah_blah
FROM my_table
GROUP BY client_id, blah_blah
票数 11
EN

Stack Overflow用户

发布于 2015-07-14 22:39:06

我会选择ROW_NUMBER()解决方案:

代码语言:javascript
复制
SELECT *
FROM (
    SELECT ROW_NUMBER() OVER(PARTITION BY [client id] ORDER BY [id] DESC) AS RN, *
    FROM table AS one
    ) AS T
WHERE T.RN = 1;
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31409541

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档