GO
 /****** 对象:  StoredProcedure [dbo].[sp_ExportDatabase]    脚本日期: 07/18/2013 12:37:26 ******/
 SET ANSI_NULLS ON
 GO
 SET QUOTED_IDENTIFIER ON
 GO
 ----该存储过程建立在新帐套中,并在新账套中执行

 if Exists(select * from sysobjects where name=N'sp_ExportDatabase' And Xtype='P')
     Drop PROCEDURE [sp_ExportDatabase]
 Go

 CREATE PROCEDURE [dbo].[sp_ExportDatabase] (
     )
 ) ----创建存储过程 sp_ExportDatabase
 AS
 Begin
       Set NoCount On
     Declare @Utb sysname     ------用户表名
     Declare @ColName sysname   ------列名
     Declare @tid int       ------用户表的ID
     Declare @sql nvarchar(MAX)------存放拼出的sql
     Declare @len int
     --定义游标取回用户建立的表
     sELECT @SourceDB=@SourceDB+'.'
     Declare Ctb Cursor For
     Select name,id From sysobjects
     Where xtype ='U' ----如果在导库过程中因某表存在错误而导致导库过程停止 ,则可以尝试修复此表。
               ----如果此表不是很重要、或是此表无法修复,则可以在此加入条件
     --And name in (tablename1,tablename2,……)
     ------tablename1,tablename2 表示不能修复的表的名字
     Order by name
     Open Ctb
     Fetch Ctb Into @Utb,@tid
     )
     Begin   ----禁用当前数据库中所有表的约束、触发器
         Select @Utb='Dbo.'+@Utb
         Select @SQL='Alter Table '+@Utb+' Disable Trigger All; '+ ' ALTER TABLE '+ @Utb +' NOCHECK CONSTRAINT All; '
         exec ( @SQL)
         Fetch Ctb Into @Utb,@tid
     End
     close ctb
     Open Ctb
         Fetch Ctb Into @Utb,@tid
         )
         Begin
           Select @Utb='Dbo.'+@Utb

           exec (' Delete ' + @Utb)

               Set @sql='['

               Open Clu
               Fetch Clu Into @ColName
               )
               Begin     ----把列名以逗号隔开,拼成字符串
                   Set @sql=@sql+ @ColName + '],['
                   Fetch Clu Into @ColName
               End
               Close Clu
               DeAllocate Clu
               ----构造字符串
               Set @len=Len(@sql)

               Begin   ----把源数据库中的表导入到当前数据库中
                   )
                   Set @sql='Insert Into '+ @Utb + ' ('+@sql+') '+' Select '+@sql+' From ' + @SourceDB+ @Utb
                   print 'Importing Table : ' +@utb+'...'
                   If Exists (Select name From syscolumns Where id=@tid and status=0x80)
                       begin
                       Select @SQl='Set IDENTITY_INSERT '+ @Utb + ' ON' + ' Delete ' + @Utb+' '+@sql
                       print @sql
                       end
                   Else
                       Select @SQl=@sql

                   Exec ( @sql)
                   If Exists (Select name From syscolumns Where id=@tid and status=0x80)
                       Exec( 'Set IDENTITY_INSERT '+ @Utb + ' Off')
                   print 'Importing Table : ' +@utb+' complete'
               End

               Fetch Next From Ctb Into @Utb,@tid
         End
     Close Ctb
     Open Ctb
     Fetch Ctb Into @Utb,@tid
     )
     Begin   ----启用当前数据库中所有表的约束、触发器
         Select @Utb='Dbo.'+@Utb
         select @sql='Alter Table '+@Utb+' Enable Trigger All '+ ' ALTER TABLE '+ @Utb +' CHECK CONSTRAINT All '
         Exec sp_executesql @sql
         Fetch Ctb Into @Utb,@tid
     End
     close ctb
     DeAllocate Ctb
 print 'Import database complete!'

 End

使用方法

Exec sp_ExportDatabase mytest   ----mytest表示源数据实体的名称

SqlServer导库语句的更多相关文章

  1. sqlserver 多库查询 sp_addlinkedserver使用方法(添加链接服务器)

    sqlserver 多库查询 sp_addlinkedserver使用方法(添加链接服务器) 我们日常使用SQL Server数据库时,经常遇到需要在实例Instance01中跨实例访问Instanc ...

  2. 【转载】C#常用数据库Sqlserver通过SQL语句查询数据库以及表的大小

    在Sqlserver数据库中,一般我们查看数据库的大小可以通过查找到数据库文件来查看,但如果要查找数据表Table的大小的话,则不可通过此方法,在Sqlserver数据库中,提供了相应的SQL语句来查 ...

  3. SqlServer 一个查询语句以致tempdb增大55G (转载)

    SqlServer 一个查询语句导致tempdb增大55G 今天操作着服务器,突然右下角提示“C盘空间不足”! 吓一跳!~ 看看C盘,还有7M!!!这么大的C盘空间怎么会没了呢?搞不好等下服务器会动不 ...

  4. SqlServer中Sql语句的逻辑执行顺序

    准备数据 Sql脚本如下,两张表,一张客户表Customers只包含customerid和city字段,一张订单表Orders包含orderid和customerid(关联Customers的cust ...

  5. SQLSERVER读懂语句运行的统计信息

    SQLSERVER读懂语句运行的统计信息 对于语句的运行,除了执行计划本身,还有一些其他因素要考虑,例如语句的编译时间.执行时间.做了多少次磁盘读等. 如果DBA能够把问题语句单独测试运行,可以在运行 ...

  6. CREATE DATABASE建库语句详解

    原创地址:http://blog.csdn.net/guguda2008/article/details/5716939 一个完整的建库语句是类似这样的: IF DB_ID('TEST') IS NO ...

  7. oracle导库

    cmd窗口直接输入导库命令即可,不需要进入sqlplus C:\Documents and Settings\Administrator> imp username/pass@orcl file ...

  8. 【转载】Sqlserver的SQL语句实现分页查询

    在应用程序的开发中,如果数据库中的数据量过于的庞大,则需要针对查询数据做分页处理,取出对应分页中的数据,在Sqlserver分页的语句写法中,有两种比较常用,一种是数据表中含有自增量Id的情况,可以根 ...

  9. SqlServer 一个查询语句导致tempdb增大55G(转载)

    SqlServer 一个查询语句导致tempdb增大55G 今天操作着服务器,突然右下角提示“C盘空间不足”! 吓一跳!~ 看看C盘,还有7M!!!这么大的C盘空间怎么会没了呢?搞不好等下服务器会动不 ...

随机推荐

  1. hdu 5621 KK's Point(数学,推理题)

    题解: 在圆上点三个点时,除圆上三个交点外,圆内没有交点:在圆上点四个点时,除圆上四个交点外,圆内出现了一个交点,因此,在N个点中每四个点便可以在圆内产生一个交点,因此N个点在圆内形成的点的个数为CN ...

  2. hdu 5510 Bazinga(暴力)

    Problem Description Ladies and gentlemen, please sit up straight. Don't tilt your head. I'm serious. ...

  3. PHP 生成UUID的方法

                                                    .                 .                 .                ...

  4. idea git merge代码

    1.点击idea 右下角的红框区域 2.出现如下截图,第一个红框是本地dev merge,也就是说可以从从本地的dev仓库merge,第二个红框表明可以从远程的git dev merge 第三个红框表 ...

  5. IE下图片切换的时候,图片总是切换不成功---根本问题是IE缓存图片

    作为WEB设计者,为了在网页展示上加强用户体验,经常会利用图象载入显示状态方法,这自然需要Image对象的onload事件. 在firefox浏览器下完成开发后,可是在IE浏览器中进行调试总不能被调用 ...

  6. js(1)不太注意的一些小事件

    确认选择 除了向用户提供信息,我们还希望从用户那里获得信息.这里就用到了confirm 消息对话框. 语法:confirm(str); 参数说明: str: 在消息对话框中要显示的文本,返回的是布尔值 ...

  7. 在Fedora 23 Server和Workstation上安装LAMP(Linux, Apache, MariaDB和PHP)

    在安装LAMP之前,建议先更新系统包$ sudo dnf update 第一步:安装Apache Web服务器1.在Fedora 23安装Apache,你可以运行下面的命令:$ sudo dnf in ...

  8. maven将jar包安装到本地仓库的命令

    进入cmd 执行以下命令: mvn install:install-file -Dfile=E:\sqljdbc4.jar -DgroupId=com.microsoft.sqlserver -Dar ...

  9. C# 1作业 2广场砖面积 护栏长度

    作业1输入圆柱体的底面半径和高求体积             static void Main(string[] args)         {               //输入圆柱体的底面半径, ...

  10. 解决Qt4.8.6+VS2010运行程序提示 FTH: (6512): *** Fault tolerant heap shim applied to current process. This is usually due to previous crashes

    这个问题偶尔碰到两次,现在又遇上了,解决办法如下: 打开注册表,设置HKLM\Software\Microsoft\FTH\Enabled 为0 打开CMD,运行Rundll32.exe fthsvc ...