WEB开发网
开发学院数据库MSSQL Server SQL Server中为现有的列添加或去掉标识属性 阅读

SQL Server中为现有的列添加或去掉标识属性

 2008-01-09 09:52:24 来源:WEB开发网   
核心提示:问题: SQL Server有一个不错的常用特性,就是标识列,SQL Server中为现有的列添加或去掉标识属性,利用这个特性,你可以轻松地在表里为每一行创建唯一的值,只要使用 Management Studio来进行改动,然后右击designer,添加一个新的列并设置为标识列,或者删除现有标识列都很简单

问题:

SQL Server有一个不错的常用特性,就是标识列。利用这个特性,你可以轻松地在表里为每一行创建唯一的值。添加一个新的列并设置为标识列,或者删除现有标识列都很简单,但是如果是要把一个现有的列改为标识列,或者去掉现有的标识列的标识属性,那应该怎么做呢?

专家解答:

要做到这一步并不容易,或者说没有什么简单易行的方法。SQL Server的设计里并没有很简单的就现有的列加上或去掉标识属性的方法。最安全的办法是,创建一个新的列并设置为标识列,或者创建一个新的表,然后把数据移植进去。

我们来看看一些例子:

例一

现有一个简单的表,表里含有两列,其中一列为标识列。

CREATE TABLE [dbo].[Test1](
  [id] [int] IDENTITY(1,1) NOT NULL,
  [name] [nchar](10) NULL
)

如果我们用SQL Server Management Studio来去掉”id”列的标识值,这样就会创建出一个新的临时表,原表的数据都移到了临时表中,然后删除原表并为新表重命名。我们可以从下面的脚本里看到这个过程。

要看到这个脚本,只要使用 Management Studio来进行改动,然后右击designer,选择"Generate Change Script"。

SQL Server中为现有的列添加或去掉标识属性

以下是引用片段:
/* To prevent any potential data loss issues, you should review this
script in detail before running it outside the context of the database designer.*/
BEGIN TRANSACTION
SET QUOTED_IDENTIFIER ON
SET ARITHABORT ON
SET NUMERIC_ROUNDABORT OFF
SET CONCAT_NULL_YIELDS_NULL ON
SET ANSI_NULLS ON
SET ANSI_PADDING ON
SET ANSI_WARNINGS ON
COMMIT
BEGIN TRANSACTION
GO
CREATE TABLE dbo.Tmp_Test1
  (
  id INT NOT NULL,
  name NCHAR(10) NULL
  ) ON [PRIMARY]
GO
IF EXISTS(SELECT * FROM dbo.Test1)
  EXEC('INSERT INTO dbo.Tmp_Test1 (id, name)
   SELECT id, name FROM dbo.Test1 WITH (HOLDLOCK TABLOCKX)')
GO
DROP TABLE dbo.Test1
GO
EXECUTE sp_rename N'dbo.Tmp_Test1', N'Test1', 'OBJECT' 
GO
COMMIT

1 2  下一页

Tags:SQL Server 现有

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接