MSSQL标识ID的修改
今天机缘巧合,无意听到别人闲聊,突发奇想设计一套系统来解决他们的痛点,待我进一步分析下如何执行。回到主题,最近修改ID的工作做了不少。企业补充历史数据用。现总结如下:
1.想把递增ID某一段的ID都加上10,本以为写一条UPDATE 语句 如下
SET IDENTITY_INSERT c1 ON
UPDATE c1 SET ID=ID+10 WHERE ID<15 AND ID>10
SET IDENTITY_INSERT c1 OFF
结果执行错误:原因如下
标识符号没法直接更新,只能改为非标识符号才能更新,修改成非标识符号会修改表的创建时间。
2.不能主表跟子表同时设置为ID递增无效
SET IDENTITY_INSERT c1 ON -- 设置标识符 可以添加 只能设置一个
SET IDENTITY_INSERT g1 ON -- 同时允许无效
SET IDENTITY_INSERT c1 OFF -- 当插入的标识ID大于现有ID 则系统按最大的进行递增
3.插入标识ID的方法
--将ID=3的记录的ID值改为2
SET IDENTITY_INSERT t1 ON
INSERT t1(ID,A) SELECT 2,A FROM t1 WHERE ID=3
DELETE FROM t1 WHERE ID=3
SET IDENTITY_INSERT t1 OFF
SET IDENTITY_INSERT c1 ON
INSERT INTO C1
(
ID
)
SELECT ID FROM dbo.g2 WHERE ID BETWEEN 50 AND 60
SET IDENTITY_INSERT c1 OFF
4.创建临时表,临时表上修改标识ID,再插入现有表格。
select * into userTemp from user where 1<>1 --复制表结构
ALTER TABLE user
ADD NEW_ID INT
GO
UPDATE user SET NEW_ID=ID --以前的增加一个字段,保留原有标识ID,便于后期维护用
GO
SET IDENTITY_INSERT C_StockUp_PackingTemp ON
INSERT INTO C_StockUp_PackingTemp
(
ID,
StockUpId,
Packing,
PackingNumb,
PackingSM,
NEW_ID
)
SELECT
ID,
StockUpId,
Packing,
PackingNumb,
PackingSM,NEW_ID FROM C_StockUp_Packing
SET IDENTITY_INSERT C_StockUp_PackingTemp OFF
--需要手动建主键,去标识符号
DECLARE @ID INT
DECLARE @i INT
SET @i=0
DECLARE cur_g5 CURSOR FOR SELECT id FROM G5 ORDER BY id
OPEN cur_g5
FETCH NEXT FROM cur_g5 INTO @ID
WHILE @@FETCH_STATUS=0
BEGIN
--PRINT CONVERT(VARCHAR,@ID)+'--'+CONVERT(VARCHAR,@i)+'--'+CONVERT(VARCHAR,@ID+@i)
UPDATE C_StockUp_PackingTemp SET ID=ID+1 WHERE ID>@ID+@i
SET @i=@i+1
FETCH NEXT FROM cur_g5 INTO @ID
END
CLOSE cur_g5
DEALLOCATE cur_g5
--DELETE FROM C_StockUp_Packing WHERE ID>81847
SET IDENTITY_INSERT C_StockUp_Packing ON
INSERT INTO C_StockUp_Packing
(
ID,
StockUpId,
Packing,
PackingNumb,
PackingSM,NEW_ID
)
SELECT
ID,
StockUpId,
Packing,
PackingNumb,
PackingSM,NEW_ID FROM C_StockUp_PackingTemp WHERE ID>93304
SET IDENTITY_INSERT C_StockUp_Packing OFF
GO
5.MSSQL有做发布订阅如何追加历史标识ID
发布订阅服务器系统默认两套数据库的ID阈值不一致,合并后数据库会有很多间隙ID可以直接插入。
sp_adjustpublisheridentityrange @table_name='表名' --ID冲突时设置表重新获取最新的阈值范围
sp_helpconstraint '表名' --查看表的约束条件;获取表的取值范围。
dbcc checkident('表名',reseed,182831) --设置标识ID的现在最大值。
以上几点我入坑很久都没有办法解决追加历史ID的功能。
其实方法很简单
alter table 表名 nocheck constraint all --禁用约束条件
导入写好数据信息
alter table 表名 check constraint all --启用约束条件
MSSQL标识ID的修改的更多相关文章
- Django项目:CMDB(服务器硬件资产自动采集系统)--04--04CMDB本地(Agent)模式客户端唯一标识(ID)
# client.py # ————————01CMDB获取服务器基本信息———————— from src import plugins #__init__.py from lib.serializ ...
- MSSQL数据库逻辑文件名修改与查看
逻辑文件名是什么 你用的程序连接的时候使用的是数据库名,然后你在你的数据库右击属性的时候,左上角单击"文件",可以看到,数据库名和逻辑文件名是不一样的,你可以看自己的数据库的路径下 ...
- mssql因为手贱修改了服务配置的最大内存,造成无法启动
mssql数据库设置内存太小,造成无法启动服务. 解决办法: 1.用命令行形式启动最精简版的mssql服务,另外再用一个新的命令行去修改配置,将内存设置为无限制. 命令行要记得用管理员身份运行比较稳 ...
- mssql数据库添加,修改,删除字段
通用式: alter table [表名] add [字段名] 字段属性 default 缺省值 default 是可选参数 增加字段: alter table [表名] add 字段名 smalli ...
- row_number()over(partition by 字段 order by 字段)ID,修改重复行的字段值。
案例分析: 现在要查询一个表单里面的运费结果,但是他还有分录,为了显示分录,必须把表头显示出来,问题是,他要查询运费的合计, 但是这样就会导致重复行也加进去了,这样显然数据不准,为此,可以把重复的行设 ...
- mybatis plus 主键生成 Twitter雪花算法 id 及修改id为字符型
mybatis plus配置主键生成策略为2,就是 使用Twitter雪花算法 生成id spring boot中配置为: GlobalConfiguration conf = new GlobalC ...
- mssql 设置id自增 设置主键
主键自增长列在进行数据插入的时候,很有用的,如可以获取返回的自增ID值,接下来将介绍SQL Server如何设置主键自增长列,感兴趣的朋友可以了解下,希望本文对你有所帮助 1.新建一数据表,里 ...
- jQuery匹配id 批量修改css属性
<ul id="foreignCurrencyTree_1_ul"> <li id="foreignCurrencyTree_11_li"&g ...
- [jnhs]id字段修改错误导致hibernate hql查询整表只返回第一条数据
调试发现,查询到的就是一条数据 hql语句执行结果 Hibernate: select ballmodel0_.ball_id as ball_id1_1_, ballmodel0_.color as ...
随机推荐
- 受邀与微软售前技术团队参与TFS技术沟通会议
微软正式发布Azure DevOps Server 2019的第一个版本,作为Team Foundation Server (TFS)2018的升级版本和替代产品. 作为开发运维一体化平台的主打产品, ...
- Spring AOP 源码分析系列文章导读
1. 简介 前一段时间,我学习了 Spring IOC 容器方面的源码,并写了数篇文章对此进行讲解.在写完 Spring IOC 容器源码分析系列文章中的最后一篇后,没敢懈怠,趁热打铁,花了3天时间阅 ...
- Poetry
1. Absence to love is what wind is to fire. It extinguishes the small; It inflames the great. 2. It ...
- JQuery 知识
1.修改标签内容: *html( ) 相当于innerHTML * text( ) 相当于innerText 2.属性操作: *attr( ) 读/写/添加/设置属性 *removeAttr ...
- nyoj 1274信道安全 第九届河南省赛(SPFA)
信道安全 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描述 Alpha 机构有自己的一套网络系统进行信息传送.情报员 A 位于节点 1,他准备将一份情报 发送给位于节点 ...
- Mysql数据优化--DBA梳理珍藏篇
1. 优化SQL 1) 通过show status了解各种sql的执行频率 show status like 'Com_%' 了解 Com_select,Com_insert 的 ...
- SQL面试题之行转列
典型的课程表: mysql> select * from course; +----+------------+----------+------------+ | id | teacher_i ...
- 06-03 Java 面向对象思想概述、开发设计特征,类和对象的定义使用,对象内存图
面向对象思想概述.开发设计特征 1:面向对象思想 面向对象是基于面向过程的编程思想. 面向过程:强调的是每一个功能的步骤 面向对象:强调的是对象,然后由对象去调用功能 2:面向对象的思想特点 A:是一 ...
- Oracle修改日志归档模式、归档路径以及空间大小的相关测试
ORACLE 创建数据库的时候要不要开启日志归档? oracle数据库可以运行在2种模式下:归档模式(archivelog)和非归档模式(noarchivelog) .归档模式可以提高Oracle数据 ...
- 关于SVM(support vector machine)----支持向量机的一个故事
一.预告篇: 很久很久以前,有个SVM, 然后,……………………被deep learning 杀死了…………………………………… . 完结……撒花 二.正式篇 好吧,关于支持向量机有一个故事 ,故事是 ...