(5.3.4)数据库迁移——数据对比(结构、数据类型)
2023-09-11 14:21:09 时间
关键词:数据对比,数据结构对比,数据类型对比
使用场景:批量对比
【1】数据结构对比(实例内)
单实例不建议使用,建议使用 red Gate 工具集中的 SQL Compare
但如果没有装软件,可以使用脚本实现
/* 作用, 1.对比2个库字段类型是否相同 2.对比2个库字段数量是否相同 */ --(1)主从表字段差异与表结构差异 use db_del go if object_id('temp_logs1') is not null drop table temp_logs1 if object_id('temp_logs2') is not null drop table temp_logs2 if object_id('temp_tank1') is not null drop table temp_tank1 if object_id('temp_tank2') is not null drop table temp_tank2 use db_logs select object_name(object_id) as tab_name,t2.name as column_type, t1.object_id,t1.name ,t1.system_type_id,t1.user_type_id,t1.max_length into db_del..temp_logs1 from sys.columns t1 join sys.types t2 on t1.user_type_id=t2.user_type_id and t1.user_type_id=t2.user_type_id use logs2 select object_name(object_id) as tab_name,t2.name as column_type, t1.object_id,t1.name,t1.system_type_id,t1.user_type_id,t1.max_length into db_del..temp_logs2 from sys.columns t1 join sys.types t2 on t1.user_type_id=t2.user_type_id and t1.user_type_id=t2.user_type_id use db_tank select object_name(object_id) as tab_name,t2.name as column_type, t1.object_id,t1.name,t1.system_type_id,t1.user_type_id,t1.max_length into db_del..temp_tank1 from sys.columns t1 join sys.types t2 on t1.user_type_id=t2.user_type_id and t1.user_type_id=t2.user_type_id use tank2 select object_name(object_id) as tab_name,t2.name as column_type, t1.object_id,t1.name,t1.system_type_id,t1.user_type_id,t1.max_length into db_del..temp_tank2 from sys.columns t1 join sys.types t2 on t1.user_type_id=t2.user_type_id and t1.user_type_id=t2.user_type_id --select logs select t1.*,t2.* from db_del..temp_logs1 t1 full join db_del..temp_logs2 t2 on t1.tab_name=t2.tab_name and t1.name=t2.name where ( t2.tab_name is null or t1.tab_name is null or t2.system_type_id!=t1.system_type_id or t2.user_type_id!= t1.user_type_id ) --select tank select t1.*,t2.* from db_del..temp_tank1 t1 full join db_del..temp_tank2 t2 on t1.tab_name=t2.tab_name and t1.name=t2.name where ( t2.tab_name is null or t1.tab_name is null or t2.system_type_id!=t1.system_type_id or t2.user_type_id!= t1.user_type_id ) --(2)获取表字段差异与表结构差异 db_tank与db_Del 可以理解成与历史库或历史表的对比 (2)这段可以忽略,用(1) 即可 --prepare use db_del go if object_id('temp_logs1') is not null drop table temp_logs1 if object_id('temp_logs2') is not null drop table temp_logs2 use db_tank select object_name(object_id) as tab_name,t2.name as column_type, t1.object_id,t1.name ,t1.system_type_id,t1.user_type_id,t1.max_length into db_del..temp_logs1 from sys.columns t1 join sys.types t2 on t1.user_type_id=t2.user_type_id and t1.user_type_id=t2.user_type_id use db_del select object_name(object_id) as tab_name,t2.name as column_type, t1.object_id,t1.name,t1.system_type_id,t1.user_type_id,t1.max_length into db_del..temp_logs2 from sys.columns t1 join sys.types t2 on t1.user_type_id=t2.user_type_id and t1.user_type_id=t2.user_type_id --select tank库为主 与del与其同步比较 select t1.*,t2.* from db_del..temp_logs1 t1 full join db_del..temp_logs2 t2 on t1.tab_name=right(t2.tab_name,len(t2.tab_name)-4) and t1.name=t2.name where t1.tab_name in ( select t1.tab_name from db_del..temp_logs1 t1 join db_del..temp_logs2 t2 on t1.tab_name=right(t2.tab_name,len(t2.tab_name)-4) ) and ( t2.tab_name is null or t1.tab_name is null or t2.system_type_id!=t1.system_type_id or t2.user_type_id!= t1.user_type_id ) --select del库为主,tank库与其同步比较
select t1.*,t2.* from db_del..temp_logs1 t1 full join db_del..temp_logs2 t2 on t1.tab_name=right(t2.tab_name,len(t2.tab_name)-4) and t1.name=t2.name where t2.tab_name in ( select t2.tab_name from db_del..temp_logs1 t1 join db_del..temp_logs2 t2 on t1.tab_name=right(t2.tab_name,len(t2.tab_name)-4) ) and ( t2.tab_name is null or t1.tab_name is null or t2.system_type_id!=t1.system_type_id or t2.user_type_id!= t1.user_type_id )
【2】跨DB对比,该段参考引用自:https://www.cnblogs.com/zhang502219048/p/11028767.html
单实例不建议使用,建议使用 red Gate 工具集中的 SQL Compare
但如果没有装软件,可以使用脚本实现
-- sysobjects插入临时表 select s.name + '.' + t.name as TableName, t.* into #tempTA from DB_V1.sys.tables t inner join DB_V1.sys.schemas s on s.schema_id = t.schema_id select s.name + '.' + t.name as TableName, t.* into #tempTB from [localhost].DB_V2.sys.tables t inner join [localhost].DB_V2.sys.schemas s on s.schema_id = t.schema_id -- syscolumns插入临时表 select * into #tempCA from DB_V1.dbo.syscolumns select * into #tempCB from [localhost].DB_V2.dbo.syscolumns -- 第一个数据库表和字段 select b.TableName as 表名, a.name as 字段名, a.length as 长度, c.name as 类型 into #tempA from #tempCA a inner join #tempTA b on b.object_id = a.id inner join systypes c on c.xusertype = a.xusertype order by b.name -- 第二个数据库表和字段 select b.TableName as 表名, a.name as 字段名, a.length as 长度, c.name as 类型 into #tempB from #tempCB a inner join #tempTB b on b.object_id = a.id inner join systypes c on c.xusertype = a.xusertype order by b.name --删掉的字段 select * from ( select * from #tempA except select * from #tempB ) a; --增加的字段 select * from ( select * from #tempB except select * from #tempA ) a; --select * from #tempA --select * from #tempB drop table #tempTA, #tempTB, #tempCA, #tempCB, #tempA, #tempB
相关文章
- 使用YII框架的migrate迁移数据库
- 【C/C++学院】(23)Mysql数据库编程--C语言编程实现mysql客户端
- 【ASM学习】普通数据库向ASM实例的迁移(一)
- .net core ef core 自动迁移,自动修改数据库
- oracle数据库导入导出命令
- 数据库设计原则
- 数据库SqlServer迁移PostgreSql实践
- EF框架中,在实体中手动更新字段,数据库数据未同步到程序中应该怎么解决呢?
- ITTC数据挖掘平台介绍(七)强化的数据库, 虚拟化,脚本编辑器
- ASP.NET关于书籍详情和删除的Demo(HttpHandler进行页面静态化[自动生成html网页]+Entity Framework通过类创建数据库+EF删查)...
- 详解MYSQL数据库密码的加密方式及破解方法
- SQL Server 2008数据库创建,备份,还原图解及注意点
- 数据库垂直拆分,水平拆分利器,cobar升级版mycat(转)
- HBase、Redis、MongoDB、Couchbase、LevelDB主流 NoSQL 数据库的对比
- 数据库同时更新问题
- mongodb 查看数据库和表大小
- 【SQLServer】DBHelper即C#数据库底层封装
- 专访神州飞象高级数据库工程师赖伟:迁移不怕难,大象肚里能撑船
- PostgreSQL 数据库开发规范
- 内存数据库H2使用
- 数据库迁移工具包:Database Migration Toolkit - v10
- 数据库数据迁移失败,如何进行修复操作
- mybatis和mybatis plus时间范围查询,数据库,sql,查询时间范围
- 〖Python 数据库开发实战 - Python与MySQL交互篇⑭〗- 项目实战 - 实现新闻管理 - 审批新闻 功能
- 数据库实践丨使用MTK迁移Mysql源库后主键自增列导致数据无法插入问题
- 对数据库表中的某一字段去重分组排序
- Qt数据库应用19-图片转pdf
- 使用RMAN Convert Database命令实现跨平台的数据库迁移