C#.NET SQL数据库备份与还原解决方案
http://www.csframework.com/archive/1/arc-1-20110924-1841.htm

开发框架V2.2(快速开发版)系统管理模块已集成数据库的备份与还原功能。

数据库列表:帐套数据库与系统数据库列表。
备份文件列表:数据源来自master.dbo.sys_BackupHistory表。


首先在master数据库建立3个存储过程及一个备份历史表:
1. p_BackupDB
2. p_RestoreDB
3. p_CreateJob
4. sys_BackupHistory --备份历史表

(脚本在下面找)


1. p_BackupDB 备份数据库存储过程

ALTER PROC [dbo].[p_BackupDB]

@DBNAME SYSNAME='',       --要备份的数据库名称,不指定则备份当前数据库

)='', --备份文件的存放目录,不指定则使用SQL默认的备份目录

)='',--备份文件名,文件名中可以用\DBNAME\代表数据库名,\DATE\代表日期,\TIME\代表时间

)='DB',--备份类型:'DB'备份数据库,'DF' 差异备份,'LOG' 日志备份

@APPENDFILE BIT=1         --追加/覆盖备份文件

AS

BEGIN

/*

p_BackupDB 'CSFramework22.Normal','C:\db_backup\'

p_BackupDB 'CSFramework22.Test','C:\db_backup\'

p_BackupDB 'CSFramework22.System','C:\db_backup\'

*/

)

IF ISNULL(@DBNAME,'')=''  SET @DBNAME=DB_NAME()--当前数据库

IF ISNULL(@BKPATH,'')=''  SET @BKPATH=dbo.f_GetDBPath(NULL)

IF ISNULL(@BKFNAME,'')='' SET @BKFNAME='\DBNAME\_\DATE\_\TIME\.BAK'

SET @BKFNAME=REPLACE(REPLACE(REPLACE(@BKFNAME,'\DBNAME\',@DBNAME)

))

),':',''))

SET @SQL='BACKUP '+CASE @BKTYPE WHEN 'LOG' THEN 'LOG ' ELSE 'DATABASE ' END

+'['+@DBNAME+']'

+' TO DISK='''+@BKPATH+@BKFNAME

+''' WITH '+CASE @BKTYPE WHEN 'DF' THEN 'DIFFERENTIAL,' ELSE '' END

+CASE @APPENDFILE WHEN 1 THEN 'NOINIT' ELSE 'INIT' END

PRINT @SQL

EXEC(@SQL)

BEGIN

PRINT '备份日志'

INSERT INTO dbo.sys_BackupHistory(DBName,BackupFileName,BackupPath,BackupTime)VALUES

(@DBNAME,@BKFNAME,@BKPATH+@BKFNAME,GETDATE())

END

END

2. p_RestoreDB 还原数据库存储过程

ALTER PROC [dbo].[p_RestoreDB]

),   --定义要恢复的备份文件名

@DBNAME SYSNAME,          --定义恢复后的数据库名,默认为备份的文件名

)='DB',--恢复类型:'DB'完整恢复数据库,'DBNOR' 为差异恢复,日志恢复进行完整恢复,'DF' 差异备份的恢复,'LOG' 日志恢复

,        --恢复的文件号

@OVEREXIST BIT=1          --是否覆盖已经存在的数据库,仅@RETYPE为

AS

BEGIN

/*

--还原数据库

p_RestoreDB 'C:\db_backup\CSFramework22.Normal_20110924_213838.BAK','CSFramework22.Normal'

--查看备份文件的内容

RESTORE FILELISTONLY FROM DISK='C:\db_backup\CSFramework22.Normal_20110924_213838.BAK'

*/

)

--得到恢复后的数据库名

IF ISNULL(@DBNAME,'')=''

SELECT @SQL=REVERSE(@BKFILE)

,@SQL=CASE WHEN CHARINDEX('.',@SQL)=0 THEN @SQL

,) END

,@SQL=CASE WHEN CHARINDEX('\',@SQL)=0 THEN @SQL

) END

,@DBNAME=REVERSE(@SQL)

--生成数据库恢复语句

SET @SQL='RESTORE '+CASE @RETYPE WHEN 'LOG' THEN 'LOG ' ELSE 'DATABASE ' END

+'['+@DBNAME+']'

+' FROM DISK='''+@BKFILE+''''

+' WITH FILE='+CAST(@FILENUMBER AS VARCHAR)

+CASE WHEN @OVEREXIST=1 AND @RETYPE IN('DB','DBNOR') THEN ',REPLACE' ELSE ''END

+CASE @RETYPE WHEN 'DBNOR' THEN ',NORECOVERY' ELSE ',RECOVERY' END

--设当前数据库离线状态

EXEC('ALTER DATABASE ['+@DBNAME+'] SET OFFLINE WITH ROLLBACK IMMEDIATE')

--恢复数据库

EXEC(@SQL)

--设当前数据库连线状态

EXEC('ALTER DATABASE ['+@DBNAME+'] SET ONLINE')

END

3.  p_CreateJob创建作业存储过程
  
(因SQLExpress 2005 没有代理服务,可以创建作业,但无法运行作业。SQL2008版本可以)

4. sys_BackupHistory 备份历史记录表

常见错误及解决方法:

1. 备份错误

SQL报错:

BACKUP DATABASE CSFrameworkPermission TO DISK='C:\CSFrameworkPermission_20110923_104732.BAK' WITH NOINIT
Msg 3201, Level 16, State 1, Line 1
Cannot open backup device 'C:\CSFrameworkPermission_20110923_104732.BAK'. Operating system error 5(拒绝访问。).
Msg 3013, Level 16, State 1, Line 1
BACKUP DATABASE is terminating abnormally.

提示操作系统错误(拒绝访问),是因为当前建立连接的用户(CSFramework)没有服务器建立文件的权限。

其它提示:

类似于NT AUTHORITY\SYSTEM权限不够的问题,请在服务管理中将SQL Server (MSSQLSERVER) 和 SQL Server Agent (MSSQLSERVER).的两个服务的登录(Log On)改为在 192.168.0.2上有权限的域帐号

解决方法:

打开SQL Server配置管理工具,在Log On页面有两种方式登录服务器。
1. Build-in account,选择Local System。
2. This account,指定一个登录用户,可以使用Administrator用户。

2. 还原错误

正常情况下设置好第一步有读写文件权限了,一般不会报错。如果仍有错误,将当前用户指定dbcreator角色。

3. 写备份历史记录时出错

 The SELECT permission was denied on the object 'sys_BackupHistory', database 'master', schema 'dbo'.

是因为当前用户没有master数据库读写权限。将csframework用户的User Mapping勾上master,设为dbo。


backup_restore_db.sql

下载:

 (VIP会员下载) 点击下载附件 (如下载失败,请邮件通知我们寄回给您,或QQ:23404761留言.)

C#.NET SQL数据库备份与还原解决方案的更多相关文章

  1. C#+SQL数据库备份和还原

    使用前要导入SQLDMO.dll(在com组件中导入Microsoft SQLDMO Object Library即可) /// /// DbOper类,主要应用SQLDMO实现对Microsoft ...

  2. SQL Server 2008数据库备份和还原(还原是必须有完整备份)

    转自lwccc, SQLserver2008数据库备份和还原问题(还原是必须有完整备份) 首先,我要说明的是你必须拥有完整的数据库备份,下面的还原教程,才算有用. 这个连接是某高手的异常恢复方法, 实 ...

  3. sql操作数据库(2)--->DQL、数据库备份和还原

    查询 查询表中的所有的行和列的数据 ​ select * from 表名; ​ select * from student; 查询指定列的数据:如果有多个列,中间用逗号隔开. select 列名1,列 ...

  4. Mysql数据库备份和还原常用的命令

    Mysql数据库备份和还原常用的命令是进行Mysql数据库备份和还原的关键,没有命令,什么都无从做起,更谈不上什么备份还原,只有给系统这个命令,让它去执行,才能完成Mysql数据库备份和还原的操作,下 ...

  5. [转]MySQL数据库备份和还原的常用命令小结

    MySQL数据库备份和还原的常用命令小结,学习mysql的朋友可以参考下: 备份MySQL数据库的命令 mysqldump -hhostname -uusername -ppassword datab ...

  6. SQL Server 备份和还原

    SQL Server 备份和还原   SQL Server 备份 恢复模式 SQL Server 数据恢复模式分为三种:完整恢复模式.大容量日志恢复模式.简单恢复模式. 完整恢复模式 默认的恢复模式, ...

  7. SQL Server 备份和还原全攻略

    原文:SQL Server 备份和还原全攻略 一.知识点 完全备份: 备份全部选中的文件夹,并不依赖文件的存档属性来确定备份那些文件.(在备份过程中,任何现有的标记都被清除,每个文件都被标记为已备份, ...

  8. MySQL具体解释(20)-----------数据库备份和还原

    数据备份: 使用mysqldump命令备份 mysqldump命令能够讲数据库中的数据备份成一个文本文件. 表结果和表中的数据将存储在生成的文本中.mysqldump的工作原理非常easy. 他先查出 ...

  9. 批处理(bat)实现SQLServer数据库备份与还原

    原文:批处理(bat)实现SQLServer数据库备份与还原 备份数据库.bat @echo off set path=%path%;C:\Program Files (x86)\Microsoft ...

随机推荐

  1. vi_命令

    1.文件末尾新增一行: 非编辑模式下,按大写的G 跳到最后一行. 然后按小写的O键,增加一行. 2.删掉一行: 非编辑状态下,光标定位到要删除的那一行,然后  dd 3.删字符 在非插入模式下,把光标 ...

  2. 2014 Multi-University Training Contest 5

    hdu4911 max(逆序数-k,0) #include <iostream> #include<stdio.h> #include<vector> #inclu ...

  3. Android notifications通知栏的使用

    app发送通知消息到通知栏中的关键代码和点击事件: package com.example.notifications; import android.os.Bundle; import androi ...

  4. Android中Activity、Service和线程之间的通信

    Activity.Service和线程应该是Android编程中最常见的几种类了,几乎大多数应用程序都会涉及到这几个类的编程,自然而然的,也就会涉及到三者之间的相互通信,本文就试图简单地介绍一下这三者 ...

  5. C++ 11 右值引用

    C++11中引入的一个非常重要的概念就是右值引用.理解右值引用是学习“移动语义”(move semantics)的基础.而要理解右值引用,就必须先区分左值与右值. 注意:左值右值翻译可能有些问题 *L ...

  6. 转:21副GIF动图让你了解各种数学概念

    21副GIF动图让你了解各种数学概念

  7. Android控件之CheckBox(复选框控件)

    一.有两种状态: 选中状态(true).未选中状态(false) 二.属性 android:id = "@+id/checkbox" android:layout_width=&q ...

  8. mac10.12的Cocopods安装使用

    Cocopods的安装 CocoaPods应该是iOS最常用最有名的类库管理当我们开发iOS应用时,会经常使用到很多第三方开源类库,比如AFNetWorking等等,可能某个类库又用到其他的库,手动一 ...

  9. http协议简述

    HTTP协议 客户端连上web 服务器后,若想获得 web 服务器中的某个 web 资源,需遵守一定的通讯格式, HTTP 协议用于定义客户端与 web 服务器通迅的格式. WEB浏览器与 WEB 服 ...

  10. IE7局部滚动区域下绝对定位或相对定位元素不随滚动条滚动的bug

    尽管在项目中测试人员已经慢慢淡化了IE6的测试,但是IE7依然还是要纳入测试范围. 最近碰到一个IE7的蛋疼bug,在页面上设置了一个局部的滚动区域,在拖动滚动条的时候,滚动区域内设置了相对定位或绝对 ...