SQLServer实例之间克隆表

场景: 两个SQLServer实例(可能在不同机器上)

(1)实例1 : SarahCla

(2)实例2:     CloneServer

目标:将SarahCla中的某些表的结构及数据克隆到CloneServer中


step 1: 在CloneServer中建立SarahCla的linkserver,执行语句如下

Exec sp_droplinkedsrvlogin [SARAHCLA],Null

EXEC  sp_addlinkedserver  
      @server='SARAHCLA',
      @srvproduct='',  
      @provider='SQLOLEDB',  
      @datasrc="SarahCla"   
     
EXEC sp_addlinkedsrvlogin   
     'SARAHCLA',
     'false',   
     NULL,   
     'sa', --帐号  
     'XXXXX' --密码     嚯嚯,差点忘了删密码 吐舌头

step 2: 在SarahCla 实例中相应的数据库中创建存储过程,获取table的创建语句。

(linkserver直接select * into 会丢掉一些列的property,例如identity)

create procedure SP_GET_TABLE_INFO
@ObjName varchar(128),       
@sql nvarchar(4000) output,
@cols nvarchar(4000) output
as

declare @Script varchar(255)
declare @ColName varchar(30)
declare @ColID   TinyInt
declare @UserType smallint
declare @TypeName sysname
declare @Length   TinyInt
declare @Prec     TinyInt
declare @Scale    TinyInt
declare @Status   TinyInt
declare @cDefault int
declare @DefaultID TinyInt
declare @Const_Key varchar(255)
declare @IndID     SmallInt  
declare @IndStatus Int
declare @Index_Key varchar(255)
declare @DBName    varchar(30)
declare @strPri_Key varchar (255)

if not Exists(Select name from sysobjects where name = @ObjName)
begin
  select @DBName = db_name()
    raiserror(15009,-1,-1,@ObjName,@DBName)
    return (1)
end

create table #spscript
(
    id     int IDENTITY not null,
    Script Varchar(255) NOT NULL,
    LastLine tinyint
)

declare Cursor_Column INSENSITIVE CURSOR
  for Select a.name,a.ColID,a.usertype,b.name,a.length,a.prec,a.scale,a.Status, a.cDefault,
        case a.cdefault when 0 then ' ' else (select c.Text from syscomments c where a.cdefault = c.id) end const_key
        from syscolumns a, systypes b where object_name(a.id) = @ObjName
        and a.usertype = b.usertype order by a.ColID

set nocount on
Select @Script = 'Create table ' + @ObjName + '('
Insert into #spscript values(@Script,0)

/* Get column information */
open Cursor_Column

fetch next from Cursor_Column into @ColName,@ColID,@UserType,@TypeName,@Length,@Prec,@Scale,
      @Status,@cDefault,@Const_Key

Select @Script = ''
while (@@FETCH_STATUS <> -1)
begin
  if (@@FETCH_STATUS <> -2)
  begin

    if (@cols='')
        set @cols = @ColName
    else
        set @cols = @cols + ',' + @Colname
        
    Select @Script = @ColName + ' ' + @TypeName
    
    if @UserType in (1,2,3,4)
      Select @Script = @Script + '(' + Convert(char(3),@Length) + ') '
    else if @UserType in (24)
      Select @Script = @Script + '(' + Convert(char(3),@Prec) + ','
                      + Convert(char(3),@Scale) + ') '
    else
      Select @Script = @Script + ' '
    if ( @Status & 0x80 ) > 0
      Select @Script = @Script + ' IDENTITY(1,1) '

    if ( @Status & 0x08 ) > 0
      Select @Script = @Script + ' NULL '
    else
      Select @Script = @Script + ' NOT NULL '
    if @cDefault > 0
      Select @Script = @Script + ' DEFAULT ' + @Const_Key
  end
  fetch next from Cursor_Column into @ColName,@ColID,@UserType,@TypeName,@Length,@Prec,@Scale, @Status,@cDefault,@Const_Key
  if @@FETCH_STATUS = 0
  begin
    Select @Script = @Script + ','
    Insert into #spscript values(@Script,0)
  end
  else
  begin
    Insert into #spscript values(@Script,1)
    Insert into #spscript values(')',0)
  end
end
Close Cursor_Column
Deallocate Cursor_Column

/* Get index information */
Declare Cursor_Index INSENSITIVE CURSOR for
    Select name,IndID,status
    from sysindexes
    where object_name(id)=@ObjName and IndID > 0 and IndID<>255  
    order by IndID   
Open Cursor_Index
Fetch Next from Cursor_Index into @ColName, @IndID, @IndStatus
while (@@FETCH_STATUS <> -1)
begin
  if @@FETCH_STATUS <> -2
  begin

    declare @i TinyInt
    declare @thiskey varchar(50)
    declare @IndDesc varchar(68)

    Select  @i = 1
    while (@i <= 16)
    begin
      select @thiskey = index_col(@ObjName, @IndID, @i)
      if @thiskey is null
        break

      if @i = 1
        select @Index_Key = index_col(@ObjName, @IndID, @i)
      else
        select @Index_Key = @Index_Key + ', ' + index_col(@ObjName, @IndID, @i)
      select @i = @i + 1
    end
    if (@IndStatus & 0x02) > 0
      Select @Script = 'Create unique '
    else
      Select @Script = 'Create '
    if @IndID = 1
      select @Script = @Script + ' clustered '


    if (@IndStatus & 0x800) > 0
     select @strPri_Key = ' PRIMARY KEY (' + @Index_Key + ')'
    else
     select @strPri_Key = ''
     
    if @IndID > 1
      select @Script = @Script + ' nonclustered '
    Select @Script = @Script + ' index ' + @ColName + ' ON '+ @ObjName
           + '(' + @Index_Key + ')'
    Select @IndDesc = ''
    if @IndStatus & 0x01 = 0x01
      Select @IndDesc = @IndDesc + ' IGNORE_DUP_KEY' + ','
    if @IndStatus & 0x40 = 0x40
      Select @IndDesc = @IndDesc + ' ALLOW_DUP_ROW' + ','
    if @IndDesc <> ''
    begin
      Select @IndDesc = SubString( @IndDesc, 1, DataLength(@IndDesc) - 1 )
      Select @Script = @Script + ' WITH ' + @IndDesc
    end
  end
  if (@strPri_Key = '')
    Insert into #spscript values(@Script,0)
  else
    update #spscript set Script = Script + @strPri_Key where LastLine = 1
 
  Fetch Next from Cursor_Index into @ColName, @IndID, @IndStatus
end
Close Cursor_Index
Deallocate Cursor_Index

declare @line varchar(8000)
set @sql = ''
Declare Cursor_sql CURSOR for Select script from #spscript
Open Cursor_sql
Fetch Next from Cursor_sql into @line
while (@@FETCH_STATUS <> -1)
begin
    set @sql = @sql + ' ' + @line
    Fetch Next from Cursor_sql into @line
end
Close Cursor_sql
Deallocate Cursor_sql



set nocount off

return (0)


step 3: 在CloneServer 上创建执行克隆任务的存储过程

create procedure tableClone
@table nvarchar(1000)
As
begin
    declare @sql nvarchar(4000);
    declare @cols nvarchar(4000);
    set @cols=''
    execute [SarahCla].master.dbo.SP_GET_TABLE_INFO @table, @sql output, @cols output;

    --SarahCla记得改成自己的linkserver name

    --master 改成自己要克隆的表所在库的名称


    execute sp_executesql @sql;
    set @sql = ' set identity_insert tb3 on; insert into ' + @table + '(' + @cols + ')
    select ' + @cols + ' From [SarahCla\Sarahcla2008].master.dbo.' + @table + ' set identity_insert ' + @table + ' off '
    execute sp_executesql @sql;
end


step 4: 克隆表

例如:要克隆 tb3

execute tableClone 'tb3'

偷笑,如果要克隆所有表,遍历sysobjects执行哈,这里就不写了。。。(懒人一个)

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值