【问题标题】:Generate row numbers and assign same row number to same values生成行号并将相同的行号分配给相同的值
【发布时间】:2019-05-02 11:23:39
【问题描述】:

我需要为每个新出现的重复值显示重复的行号。

带有AGENT_CODE 列的示例表orders,我希望预期的输出类似于

Sl  agent_code
------------------
1   A001
2   A002
2   A002
2   A002
2   A002
2   A002
2   A002
2   A002
3   A003
3   A003
4   A004
4   A004
4   A004
4   A004
5   A007
5   A007
5   A007
6   A008
6   A008

通过编写查询,我能够获得具有 1,2,3,4....19 之类的序列的行号:

SET @row_number := 0;
SELECT @row_number := @row_number + 1 AS row_number, AGENT_CODE
FROM orders, (SELECT @row_number := 0) t
ORDER BY agent_code

但我想要的是行号必须按预期输出中所示的每次新出现的顺序打印。

【问题讨论】:

  • 你使用的是什么 MySQL 版本?
  • 5.2.37 MySQL 服务器
  • 您需要先在派生表中进行显式排序。阅读此答案以了解您得到错误结果的原因:stackoverflow.com/a/53465139/2469308

标签: mysql sql dense-rank


【解决方案1】:

你想要类似于DENSE_RANK() OVER (ORDER BY AGENT_CODE) 的东西,它需要 MySQL 8+。在旧版本中,您可以简单地这样做:

SELECT AGENT_CODE, (
    SELECT COUNT(DISTINCT AGENT_CODE) + 1
    FROM orders AS x
    WHERE x.AGENT_CODE < t.AGENT_CODE
) AS sn
FROM orders AS t

PS:如果你想使用用户变量,那么你需要另一个名为@prevagent的变量。

【讨论】:

  • 不应该是WHERE x.AGENT_CODE &lt; t.AGENT_CODEWHERE x.AGENT_CODE &lt;= t.AGENT_CODE
  • 不,我忘了给COUNT(*)加1。
  • 嘿@Salman A 这似乎可行,但我将如何从 1 开始,因为你的输出是从 0 开始的。
猜你喜欢
  • 2022-01-27
  • 1970-01-01
  • 1970-01-01
  • 2015-10-25
  • 1970-01-01
  • 1970-01-01
  • 2019-06-23
  • 2019-08-12
  • 2020-06-19
相关资源
最近更新 更多