日期:2014-05-18  浏览次数:20346 次

数据库迁移更新脚本问题
两个数据库A和B, B数据库是在A数据库基础上修改产生,主要是增加删除了部分表的字段
在不破坏A数据情况下,如何快速将B数据库结构更新到A,或者将A数据库中数据快速迁移到B,最好能够批量生产脚本完成,表太多,手工一条一条语句编写会累死的

------解决方案--------------------
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 = '表名称'

------解决方案--------------------
批量导出脚本,用导出工具就可以
------解决方案--------------------
用复制订阅,或者创建a数据库的脚本,新建数据库,执行a数据库脚本,再将b库数据库导入到新库中
------解决方案--------------------
将以下的查询语句,在sqlserver上查询,将结果集,复制到文本就可以了啊,

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'))
 --依次类推

------解决方案--------------------
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