• <tfoot id='MK8XM'></tfoot>

      <small id='MK8XM'></small><noframes id='MK8XM'>

      <legend id='MK8XM'><style id='MK8XM'><dir id='MK8XM'><q id='MK8XM'></q></dir></style></legend>

      • <bdo id='MK8XM'></bdo><ul id='MK8XM'></ul>

        <i id='MK8XM'><tr id='MK8XM'><dt id='MK8XM'><q id='MK8XM'><span id='MK8XM'><b id='MK8XM'><form id='MK8XM'><ins id='MK8XM'></ins><ul id='MK8XM'></ul><sub id='MK8XM'></sub></form><legend id='MK8XM'></legend><bdo id='MK8XM'><pre id='MK8XM'><center id='MK8XM'></center></pre></bdo></b><th id='MK8XM'></th></span></q></dt></tr></i><div id='MK8XM'><tfoot id='MK8XM'></tfoot><dl id='MK8XM'><fieldset id='MK8XM'></fieldset></dl></div>

        SQL Server,如何在不丢失数据的情况下创建表后设置自动增量?

        SQL Server, How to set auto increment after creating a table without data loss?(SQL Server,如何在不丢失数据的情况下创建表后设置自动增量?)
        <i id='7d265'><tr id='7d265'><dt id='7d265'><q id='7d265'><span id='7d265'><b id='7d265'><form id='7d265'><ins id='7d265'></ins><ul id='7d265'></ul><sub id='7d265'></sub></form><legend id='7d265'></legend><bdo id='7d265'><pre id='7d265'><center id='7d265'></center></pre></bdo></b><th id='7d265'></th></span></q></dt></tr></i><div id='7d265'><tfoot id='7d265'></tfoot><dl id='7d265'><fieldset id='7d265'></fieldset></dl></div>
        <legend id='7d265'><style id='7d265'><dir id='7d265'><q id='7d265'></q></dir></style></legend>
          <tbody id='7d265'></tbody>

              <small id='7d265'></small><noframes id='7d265'>

              <tfoot id='7d265'></tfoot>
                  <bdo id='7d265'></bdo><ul id='7d265'></ul>
                • 本文介绍了SQL Server,如何在不丢失数据的情况下创建表后设置自动增量?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我在 SQL Server 2008 中有一个表 table1,其中有记录.

                  I have a table table1 in SQL server 2008 and it has records in it.

                  我希望主键 table1_Sno 列是一个自动递增的列.这可以在不进行任何数据传输或表克隆的情况下完成吗?

                  I want the primary key table1_Sno column to be an auto-incrementing column. Can this be done without any data transfer or cloning of table?

                  我知道我可以使用 ALTER TABLE 添加自动增量列,但是我可以简单地将 AUTO_INCREMENT 选项添加到作为主键的现有列吗?

                  I know that I can use ALTER TABLE to add an auto-increment column, but can I simply add the AUTO_INCREMENT option to an existing column that is the primary key?

                  推荐答案

                  更改 IDENTITY 属性实际上只是元数据更改.但是直接更新元数据需要在单用户模式下启动实例并处理 sys.syscolpars 中的一些列,并且没有记录/不受支持,我不会推荐或将提供任何其他详细信息.

                  Changing the IDENTITY property is really a metadata only change. But to update the metadata directly requires starting the instance in single user mode and messing around with some columns in sys.syscolpars and is undocumented/unsupported and not something I would recommend or will give any additional details about.

                  对于在 SQL Server 2012+ 上遇到这个答案的人,目前实现自动递增列结果的最简单方法是创建一个 SEQUENCE 对象并设置 next 值for seq 作为列默认值.

                  For people coming across this answer on SQL Server 2012+ by far the easiest way of achieving this result of an auto incrementing column would be to create a SEQUENCE object and set the next value for seq as the column default.

                  或者,对于以前的版本(从 2005 年开始),解决方法发布在 此连接项 显示了一种完全受支持的方法,无需使用 ALTER TABLE...SWITCH<进行数据操作的大小/代码>.还在 MSDN 上写了博客 此处.虽然实现这个的代码不是很简单,并且有一些限制——比如被改变的表不能成为外键约束的目标.

                  Alternatively, or for previous versions (from 2005 onwards), the workaround posted on this connect item shows a completely supported way of doing this without any need for size of data operations using ALTER TABLE...SWITCH. Also blogged about on MSDN here. Though the code to achieve this is not very simple and there are restrictions - such as the table being changed can't be the target of a foreign key constraint.

                  CREATE TABLE dbo.tblFoo 
                  (
                  bar INT PRIMARY KEY,
                  filler CHAR(8000),
                  filler2 CHAR(49)
                  )
                  
                  
                  INSERT INTO dbo.tblFoo (bar)
                  SELECT TOP (10000) ROW_NUMBER() OVER (ORDER BY (SELECT 0))
                  FROM master..spt_values v1, master..spt_values v2
                  

                  将其更改为具有 identity 列(或多或少是即时的).

                  Alter it to have an identity column (more or less instant).

                  BEGIN TRY;
                      BEGIN TRANSACTION;
                  
                      /*Using DBCC CHECKIDENT('dbo.tblFoo') is slow so use dynamic SQL to
                        set the correct seed in the table definition instead*/
                      DECLARE @TableScript nvarchar(max)
                      SELECT @TableScript = 
                      '
                      CREATE TABLE dbo.Destination(
                          bar INT IDENTITY(' + 
                                       CAST(ISNULL(MAX(bar),0)+1 AS VARCHAR) + ',1)  PRIMARY KEY,
                          filler CHAR(8000),
                          filler2 CHAR(49)
                          )
                  
                          ALTER TABLE dbo.tblFoo SWITCH TO dbo.Destination;
                      '       
                      FROM dbo.tblFoo
                      WITH (TABLOCKX,HOLDLOCK)
                  
                      EXEC(@TableScript)
                  
                  
                      DROP TABLE dbo.tblFoo;
                  
                      EXECUTE sp_rename N'dbo.Destination', N'tblFoo', 'OBJECT';
                  
                  
                      COMMIT TRANSACTION;
                  END TRY
                  BEGIN CATCH
                      IF XACT_STATE() <> 0 ROLLBACK TRANSACTION;
                      PRINT ERROR_MESSAGE();
                  END CATCH;
                  

                  测试结果.

                  INSERT INTO dbo.tblFoo (filler,filler2) 
                  OUTPUT inserted.*
                  VALUES ('foo','bar')
                  

                  给予

                  bar         filler    filler2
                  ----------- --------- ---------
                  10001       foo       bar      
                  

                  清理

                  DROP TABLE dbo.tblFoo
                  

                  这篇关于SQL Server,如何在不丢失数据的情况下创建表后设置自动增量?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Select n random rows from SQL Server table(从 SQL Server 表中随机选择 n 行)
                  SQL query to select dates between two dates(用于选择两个日期之间的日期的 SQL 查询)
                  How can I delete using INNER JOIN with SQL Server?(如何在 SQL Server 中使用 INNER JOIN 进行删除?)
                  Table Naming Dilemma: Singular vs. Plural Names(表命名困境:单数与复数名称)
                  INSERT statement conflicted with the FOREIGN KEY constraint - SQL Server(INSERT 语句与 FOREIGN KEY 约束冲突 - SQL Server)
                  Optimal way to concatenate/aggregate strings(连接/聚合字符串的最佳方式)
                    <tbody id='dhUWw'></tbody>

                  <legend id='dhUWw'><style id='dhUWw'><dir id='dhUWw'><q id='dhUWw'></q></dir></style></legend>
                      <bdo id='dhUWw'></bdo><ul id='dhUWw'></ul>

                    • <small id='dhUWw'></small><noframes id='dhUWw'>

                      1. <tfoot id='dhUWw'></tfoot>

                          • <i id='dhUWw'><tr id='dhUWw'><dt id='dhUWw'><q id='dhUWw'><span id='dhUWw'><b id='dhUWw'><form id='dhUWw'><ins id='dhUWw'></ins><ul id='dhUWw'></ul><sub id='dhUWw'></sub></form><legend id='dhUWw'></legend><bdo id='dhUWw'><pre id='dhUWw'><center id='dhUWw'></center></pre></bdo></b><th id='dhUWw'></th></span></q></dt></tr></i><div id='dhUWw'><tfoot id='dhUWw'></tfoot><dl id='dhUWw'><fieldset id='dhUWw'></fieldset></dl></div>