复制SqlServer数据库的方法

时间:2024-01-26 22:46:26 

在目前的工作中需要解决复制整个SqlServer数据库的问题,复制的内容包括数据库大纲、数据库中的存储过程、函数、表结构、主外键关系以及表中的所有数据等,也就是说copy版本与原数据库一模一样。经过一段时间的摸索,找到的一个比较简单的解决方案是:
(1)在复制数据库之前,先备份该数据库到文件。
(2)依据备份文件创建新的数据库,并Restore即可。
   备份数据库可用如下Sql语句: 


string.Format("backup database {0} to disk = '{1}';", dbName, bakFilePath) 

  依据备份文件创建并Restore新数据库可以使用如下存储过程实现: 


CREATE PROCEDURE CopyDB 

@newDbName varchar(50),  --新数据库名称 
@dbDataDirPath varchar(100), --数据库安装的Data文件夹目录路径 
@soureDbName varchar(100), --源数据库名称 
@soureBackupFilePATH varchar(100)--源数据库备份文件的路径 

AS 
declare @sql varchar(3000) 
set @sql=' 
create database '+@newDbName+' 
ON 

  name='+@soureDbName+'_Data, 
  filename='''+@dbDataDirPath+@newDbName+'_Data.mdf'', 
   SIZE = 10, 
   FILEGROWTH = 15%  

LOG ON 

  name='''+@soureDbName+'_Log'', 
  filename='''+@dbDataDirPath+@newDbName+'_Log.LDF'', 
   SIZE = 5MB, 
   MAXSIZE = 25MB, 
   FILEGROWTH = 5MB 

--开始还原 
RESTORE DATABASE '+@newDbName+' from disk='''+@soureBackupFilePATH+''' WITH REPLACE 

exec(@sql) 
GO 


   测试的代码如下: 
 


               IList<SPParameter> paraList = new List<SPParameter>(); 
                SPParameter para1 = new SPParameter("newDbName", ParameterDirection.Input, "EASNew9"); 
                paraList.Add(para1); 
                SPParameter para2 = new SPParameter("dbDataDirPath", ParameterDirection.Input, @"C:\Program Files\Microsoft SQL Server\MSSQL\Data\"); 
                paraList.Add(para2);  
                SPParameter para3 = new SPParameter("soureDbName", ParameterDirection.Input, "AutoSchedulerSystem"); 
                paraList.Add(para3); 
                SPParameter para4 = new SPParameter("soureBackupFilePATH", ParameterDirection.Input, @"d:\sqlDatabase\AutoSchedulerSystem"); 
                paraList.Add(para4); 
                IDictionary<string, object> outParas = null; 
                Program.DataAccesser.GetSPAccesser(null).ExcuteNoneQuery("CopyDB", paraList, out outParas);
标签:复制SqlServer数据库的方法
0
投稿

猜你喜欢

  • python 怎样进行内存管理

    2021-04-27 16:46:18
  • 基于OpenCV的摄像头测距的实现示例

    2022-03-26 05:29:20
  • Python3.4学习笔记之列表、数组操作示例

    2021-04-10 10:56:11
  • 删除sqlserver数据库日志和没有日志的数据库恢复办法

    2024-01-21 23:20:55
  • 升级SQL Server 2014的四个要点要注意

    2024-01-18 09:58:01
  • uniapp小程序实战之利用腾讯地图获取定位

    2024-04-16 09:49:44
  • 给页面 unload 加上效果

    2009-03-12 12:32:00
  • python矩阵的基本运算及各种操作

    2023-01-12 11:37:27
  • pytorch K折交叉验证过程说明及实现方式

    2021-01-11 16:05:08
  • Python基于checksum计算文件是否相同的方法

    2022-11-08 20:30:48
  • 详解Python的多线程定时器threading.Timer

    2023-04-07 03:33:43
  • 批量替换sqlserver数据库挂马字段并防范sql注入攻击的代码

    2024-01-28 08:03:47
  • Python在cmd上打印彩色文字实现过程详解

    2022-12-19 07:27:33
  • sql 存储过程批量删除数据的语句

    2024-01-21 17:40:23
  • 基于Python实现微信自动回复功能

    2021-10-17 14:01:54
  • Python单体模式的几种常见实现方法详解

    2021-02-24 04:45:51
  • 在python中logger setlevel没有生效的解决

    2021-12-13 16:03:01
  • golang中for range的取地址操作陷阱介绍

    2024-04-23 09:36:39
  • 详解Python不同版本之间的切换方法

    2023-12-28 05:22:06
  • vue-element如何实现动态换肤存储

    2024-04-27 15:57:35
  • asp之家 网络编程 m.aspxhome.com