如何使主键id更改后严格升序排列(例如原id1,2,4更改后为1,2,3)
时间:2011-12-02
来源:互联网
如何使主键id更改后严格升序排列(例如原id1,2,4更改后为1,2,3)
作者: qq1107489407 发布时间: 2011-12-02
如果逐渐id为自增列就没这个必要了,序号无所谓,最大查询的时候row_number排序加个编号
作者: ssp2009 发布时间: 2011-12-02
自增是个标识列,不要去修改,如果有流水号的需要可以找找流水号的资料。
作者: AcHerat 发布时间: 2011-12-02
SQL code
利用触发器实现标识列连续。(支持批量插入) if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[ttt]') and OBJECTPROPERTY(id, N'IsUserTable') = 1) drop table [dbo].[ttt] GO /****** Object: Table [dbo].[ttt] Script Date: 2008-12-15 17:11:26 ******/ CREATE TABLE [dbo].[ttt] ( [id] [int] IDENTITY (1, 1) NOT NULL , [name] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL , [time] [datetime] NULL ) ON [PRIMARY] GO ALTER TABLE [dbo].[ttt] ADD CONSTRAINT [PK_ttt] PRIMARY KEY CLUSTERED ( [id] ) ON [PRIMARY] GO insert into ttt(name,time) values('logan',getdate()); insert into ttt(name,time) values('peter',getdate()); insert into ttt(name,time) values('man',getdate()); insert into ttt(name,time) values('lida',getdate()); insert into ttt(name,time) values('fcuandy',getdate()); select * from ttt /* 1 logan 2008-12-15 17:36:37.780 2 peter 2008-12-15 17:36:37.780 3 man 2008-12-15 17:36:37.780 4 lida 2008-12-15 17:36:37.780 5 fcuandy 2008-12-15 17:36:37.793 */ GO CREATE TRIGGER tr ON ttt INSTEAD OF INSERT AS SET IDENTITY_INSERT ttt ON DECLARE @n INT SELECT @n=MAX(id) FROM ttt ;WITH fc AS ( SELECT n=1 UNION ALL SELECT nn=n+1 FROM fc WHERE n<@n ),fc1 AS ( SELECT n FROM fc a LEFT JOIN ttt b ON a.n = b.id WHERE b.id IS NULL ) INSERT ttt(id,name,time) SELECT n,name,time FROM (SELECT ROW_NUMBER() OVER (ORDER BY GETDATE()) idx,n FROM fc1) a INNER JOIN ( SELECT idx=ROW_NUMBER() OVER (ORDER BY GETDATE()),name,time FROM inserted ) b ON a.idx=b.idx DECLARE @r INT SELECT @r=@@ROWCOUNT SET IDENTITY_INSERT ttt OFF INSERT ttt(name,time) SELECT name,time FROM ( SELECT idx=ROW_NUMBER() OVER (ORDER BY GETDATE()),name,time FROM inserted ) x WHERE idx>@r GO DELETE FROM ttt WHERE name = 'peter' OR name='lida' GO INSERT ttt SELECT 'xxx',getdate() INSERT ttt SELECT 'yyy',GETDATE() GO SELECT * FROM ttt /* 1 logan 2008-12-15 17:37:20.967 2 xxx 2008-12-15 17:37:21.013 3 man 2008-12-15 17:37:20.967 4 yyy 2008-12-15 17:37:21.030 5 fcuandy 2008-12-15 17:37:20.967 */ DELETE FROM ttt WHERE name ='xxx' OR name='yyy' INSERT ttt SELECT 'roy_88',GETDATE() UNION ALL SELECT 'limpire',GETDATE() UNION ALL SELECT '熊',GETDATE() SELECT * FROM ttt /* 1 logan 2008-12-15 17:38:29.450 2 roy_88 2008-12-15 17:38:29.530 3 man 2008-12-15 17:38:29.467 4 limpire 2008-12-15 17:38:29.530 5 fcuandy 2008-12-15 17:38:29.467 6 熊 2008-12-15 17:38:29.530 */ 本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/fcuandy/archive/2008/12/15/3522876.aspx
作者: fredrickhu 发布时间: 2011-12-02
感觉没必要。
作者: fredrickhu 发布时间: 2011-12-02
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28