数据库迁移更新脚本问题
时间:2011-12-10
来源:互联网
两个数据库A和B, B数据库是在A数据库基础上修改产生,主要是增加删除了部分表的字段
在不破坏A数据情况下,如何快速将B数据库结构更新到A,或者将A数据库中数据快速迁移到B,最好能够批量生产脚本完成,表太多,手工一条一条语句编写会累死的
在不破坏A数据情况下,如何快速将B数据库结构更新到A,或者将A数据库中数据快速迁移到B,最好能够批量生产脚本完成,表太多,手工一条一条语句编写会累死的
作者: lzcoolan 发布时间: 2011-12-10
SQL code
根据sysobjects及表syscolumns处理,如果只是增删字段的话,根据表名称,再对比字段名称即可, 如更改数据类型,则需要更多比较. 查询单表结构代码如下: select d.name as table_name,a.name as column_name ,a.colorder as column_order,a.* FROM syscolumns a inner join sysobjects d on a.id=d.id and d.xtype='U' where d.name = '表名称'
作者: jyh070207 发布时间: 2011-12-10
批量导出脚本,用导出工具就可以
作者: ssp2009 发布时间: 2011-12-10
用复制订阅,或者创建a数据库的脚本,新建数据库,执行a数据库脚本,再将b库数据库导入到新库中
作者: octwind 发布时间: 2011-12-10
将以下的查询语句,在sqlserver上查询,将结果集,复制到文本就可以了啊,
SQL code
SQL code
select distinct 'if not exists (select * from syscolumns where id=object_id(N'''++a.name+''') and name=N'''+b.name+''') begin alter table '+a.name+' add '+b.name+' '+c.name from sysobjects a inner join syscolumns b on a.id=b.id and a.xtype=N'U' left join systypes c on(b.xtype=c.xtype and c.name not in('varchar','char','nvarchar')) select distinct 'if not exists (select * from syscolumns where id=object_id(N'''++a.name+''') and name=N'''+b.name+''') begin alter table '+a.name+' add '+b.name+' '+c.name+'('+CAST(c.length as varchar(4))+')' from sysobjects a inner join syscolumns b on a.id=b.id and a.xtype=N'U' left join systypes c on(b.xtype=c.xtype and c.name in('varchar','char','nvarchar')) --依次类推
作者: bushy 发布时间: 2011-12-10
SQL code
复制表结构的通用存储过程 -- Transfer对象的重要属性 -- 1. 属性 属性名 类型 描述 --------------------------------- ------------------- -------------------- CopyAllDefaults Boolean 所有默认值 CopyAllObjects Boolean 所有对象 CopyAllRules Boolean 所有规则 CopyAllStoredProcedures Boolean 所有存储过程 CopyAllTables Boolean 所有表 CopyAllTriggers Boolean 所有触发器 CopyAllUserDefinedDatatypes Boolean 所有用户自定义类型 CopyAllViews Boolean 所有视图 CopyData Boolean 所有数据 DestDatabase String 目标对象数据库 DestLogin String 目标数据库登陆用户名 DestPassword String 目标数据库登陆密码 DestServer String 目标服务器 DestUseTrustedConnection Boolean 用户信任连接 DropDestObjectsFirst Boolean 是否先删除目标对象 IncludeDependencies Boolean 是否包含依靠对象 ScriptType Boolean 脚本类型 -- 2. 重要方法: 方法名称 功能描述 --------------------------- -------------------------- AddObject 增加对象 AddObjectByName 通过对象名称增加对象 if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[P_CopyDB]') and OBJECTPROPERTY(id, N'IsProcedure') = 1) drop procedure [dbo].[P_CopyDB] GO /*-- 在 SQLServer 中使用SQLDMO.Transfer 实现数据迁移 存储过程实现源数据库到目标数据库的对象和数据的复制 要求源数据库和目标数据库在同一服务器 如果是要实现不同服务器之间的复制,则需要增加验证信息 --邹建 2005.07(引用请保留此信息)--*/ /*--调用示例 CREATE DATABASE test EXEC P_CopyDB @Source_DB='northwind',@Des_DB='test' DROP DATABASE test --*/ CREATE PROCEDURE P_CopyDB @Des_DB sysname, --目标数据库 @Obj_Type nvarchar(4000)=N'',--复制的对象类型,可以是下列字符串列表: -- O 所有对象,D 默认值,R 规则,P 存储过程 -- T 表,TR 触发器,DT 用户定义数据类型 -- V 视图,DATA 数据,DEL 删除目标对象 @Source_DB sysname=N'', --源数据库 @ServerName sysname=N'', --服务器名 @UserName sysname=N'', --用户名,不指定则表示使用 Windows 身份登录 @pwd sysname=N'' --密码 AS SET NOCOUNT ON DECLARE @srvid int,@Dbid int,@S_dbid int,@D_dbid int,@TransferID int, @err int,@src varchar(255), @desc varchar(255) IF ISNULL(@ServerName,N'')=N'' SET @ServerName=@@SERVERNAME IF ISNULL(@Source_DB,N'')=N'' SET @Source_DB=DB_NAME() --创建sqldmo对象· EXEC @err=sp_oacreate 'sqldmo.sqlserver',@srvid OUT IF @err<>0 GOTO lb_Err --连接服务器 IF ISNULL(@UserName,N'')=N'' --使用 Windows 身份登录 BEGIN EXEC @err=sp_oasetproperty @srvid,'loginsecure',-1 IF @err<>0 GOTO lb_Err EXEC @err=sp_oamethod @srvid,'connect',NULL,@servername END ELSE EXEC @err=sp_oamethod @srvid,'connect',NULL,@servername,@UserName,@pwd IF @err<>0 GOTO lb_Err --获取数据库集 EXEC @err=sp_oagetproperty @srvid,'databases',@Dbid OUT IF @err<>0 GOTO lb_Err --选择源数据库 EXEC @err=sp_oamethod @Dbid,'item',@S_dbid OUT,@Source_DB IF @err<>0 GOTO lb_Err --选择目标数据库 EXEC @err=sp_oamethod @Dbid,'item',@D_dbid OUT,@Des_DB IF @err<>0 GOTO lb_Err --设置复制的对象 EXEC @err=sp_oacreate 'SQLDMO.Transfer',@TransferID OUT IF @err<>0 GOTO lb_Err --设置目标服务器信息 EXEC @err=sp_oasetproperty @TransferID,'DestServer',@ServerName IF @err<>0 GOTO lb_Err --设置连接用户 IF ISNULL(@UserName,N'')=N'' --使用 Windows 身份登录 BEGIN EXEC @err=sp_oasetproperty @TransferID,'DestUseTrustedConnection',1 IF @err<>0 GOTO lb_Err END ELSE BEGIN EXEC @err=sp_oasetproperty @TransferID,'DestLogin',@UserName IF @err<>0 GOTO lb_Err EXEC @err=sp_oasetproperty @TransferID,'DestPassword',@pwd IF @err<>0 GOTO lb_Err END --设置复制对象信息 EXEC @err=sp_oasetproperty @TransferID,'DestDatabase',@Des_DB IF @err<>0 GOTO lb_Err DECLARE tb CURSOR FAST_FORWARD LOCAL FOR SELECT Name FROM( SELECT KeyWord=N',D,', Name=N'CopyAllDefaults' UNION ALL SELECT KeyWord=N',O,', Name=N'CopyAllObjects' UNION ALL SELECT KeyWord=N',R,', Name=N'CopyAllRules' UNION ALL SELECT KeyWord=N',P,', Name=N'CopyAllStoredProcedures' UNION ALL SELECT KeyWord=N',T,', Name=N'CopyAllTables' UNION ALL SELECT KeyWord=N',TR,', Name=N'CopyAllTriggers' UNION ALL SELECT KeyWord=N',DT,', Name=N'CopyAllUserDefinedDatatypes' UNION ALL SELECT KeyWord=N',V,', Name=N'CopyAllViews' UNION ALL SELECT KeyWord=N',DATA,',Name=N'CopyData' UNION ALL SELECT KeyWord=N',DEL,', Name=N'DropDestObjectsFirst' )A WHERE CHARINDEX(KeyWord, CASE WHEN ISNULL(@Obj_Type,N'')='' THEN ',O,DATA,' ELSE @Obj_Type END)>0 OPEN tb FETCH tb INTO @src WHILE @@FETCH_STATUS=0 BEGIN EXEC @err=sp_oasetproperty @TransferID,@src,1 IF @err<>0 GOTO lb_Err FETCH tb INTO @src END CLOSE tb DEALLOCATE tb --复制对象 EXEC @err=sp_oamethod @S_dbid,'Transfer',null,@TransferID IF @err<>0 GOTO lb_Err --结束 SET @err=0 GOTO lb_Exit --错误处理 lb_Err: EXEC sp_oageterrorinfo NULL, @src OUT, @desc OUT RAISERROR(N'错误编号 %#x, 错误源 "%s", 错误描述 "%s"',16,1,@err,@src,@desc) RETURN -1 lb_Exit: EXEC sp_OADestroy @Dbid EXEC sp_OADestroy @srvid EXEC sp_OADestroy @TransferID RETURN @err GO
作者: fredrickhu 发布时间: 2011-12-10
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28