更改表以根据 Order By 添加 Identity 列
- 作者: 后话_
- 来源: 51数据库
- 2022-11-16
问题描述
我有这张桌子
人
------------------------------------ | **Id** |**Name** | **Created** | ------------------------------------ | Guid1 | John Doe | 2016-01-01 | ------------------------------------ | Guid2 | Mary Jane| 2015-01-01 | ------------------------------------
列 ID 是 PK 和聚集索引,所以我想添加一个标识列:
Column Id is the PK and a Clustered Index, so I want to add an Identity Column:
ALTER TABLE [Person] ADD IdentityCol INT IDENTITY(1,1) NOT NULL
问题是,每次我尝试这样做时,它都会根据表的默认顺序添加 IdentityCol 的值,我认为它是由列 Id 定义的
The problem is that every time when I try to do this, it adds the value of IdentityCol, based on the default order of the table, which I suppose is defined by the column Id
人
------------------------------------------------- | **Id** |**Name** | **Created** | IdentityCol| ------------------------------------------------- | Guid1 | John Doe | 2016-01-01 | 1 | ------------------------------------------------- | Guid2 | Mary Jane| 2015-01-01 | 2 | -------------------------------------------------
购买我想要的是按创建列创建值顺序
Buy what I want is that create the values order by Created column
------------------------------------------------- | **Id** |**Name** | **Created** | IdentityCol| ------------------------------------------------- | Guid1 | John Doe | 2016-01-01 | 2 | ------------------------------------------------- | Guid2 | Mary Jane| 2015-01-01 | 1 | -------------------------------------------------
有什么办法可以在 ALTER 语句中指定 Order By 吗?
Is there any way to specify the Order By in ALTER sentence?
推荐答案
使用行号:
UPDATE Person p
SET IdentityCol = (SELECT ROW_NUMBER() over (ORDER BY Created) AS rn
FROM Person t WHERE p.Id = t.Id)
然后您可以通过以下方式将 IdentityCol 设置为正式身份列:
Then you could set the IdentityCol as a formal identity column via:
SET IDENTITY_INSERT database.schema.Person ON
推荐阅读
热点文章
检查拆分键盘
0
带有“上一个"的工具栏和“下一个"用于键盘输入AccessoryView
0
Activity 启动时显示软键盘
0
UIWebView 键盘 - 摆脱“上一个/下一个/完成"酒吧
0
在 iOS7 中边缘滑动时,使键盘与 UIView 同步动画
0
我的 iOS 应用程序中的键盘在 iPhone 6 上太高了.如何在 XCode 中调整键盘的分辨率?
0
android:inputType="textEmailAddress";- '@' 键和 '.com' 键?
0
禁用 iPhone 中键盘的方向
0
Android 2.3 模拟器上的印地语键盘问题
0
keyDown 没有被调用
0
