簡體   English   中英

另一列上下文中的 SQL 唯一自動增量列

[英]SQL unique auto-increment column in the context of another column

我想在現有表中創建一個基於Prefix列的自動遞增鍵的列,輸出預期如下:

字首 ID
123 1
123 1
444 2
111 3
999 4
123 1
444 2

你知道如何做到這一點的任何簡單的解決方案嗎? 我找到了 mysql 的解決方案,但它不起作用。 我正在使用帶有 sql server 的 sql management studio

我嘗試了這個問題的解決方案,但它不起作用。 我有錯誤

您可以使用dense_rank()

select t.*, dense_rank() over (order by prefix) as id
from t;

在 SQL Server 中,您可以將其表述為可更新的 CTE:

with toupdate as (
      select t.*, dense_rank() over (order by prefix) as new_id
      from t
     )
update toupdate
    set id = new_id;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM