asp.net 备份和恢复数据库
观看了Insus的视频写下来的,代码可能有点冗长,如有好的想法的,可以多交流。
前台:
<form id="form1" runat="server">
<div>
<asp:Button ID="Button1" runat="server" Text="备份数据库" OnClick="Button1_Click" />
<asp:Label ID="Label1" runat="server" Text=""></asp:Label>
<asp:Label ID="Label2" runat="server" Text=""></asp:Label>
<asp:GridView ID="gv_DataBasefile" runat="server" AutoGenerateColumns="False" Width="100%"
OnRowCommand="gv_DataBasefile_RowCommand">
<RowStyle HorizontalAlign="center" />
<Columns>
<asp:TemplateField HeaderText="文件名">
<ItemTemplate>
<%#Eval("Name") %>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="创建时间">
<ItemTemplate>
<%# objIdtu.GetDateTime( Eval("CreationTime"),"yyyy-MM-dd HH:mm:ss")%>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="修改时间">
<ItemTemplate>
<%# objIdtu.GetDateTime(Eval("LastWriteTime"), "yyyy-MM-dd HH:mm:ss")%>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="路径">
<ItemTemplate>
<%# Eval("DirectoryName")%>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="还原">
<ItemTemplate>
<%--CommandArgument 传递两个数据 Name,DirectoryName--%>
<asp:ImageButton ID="ImageButton1" runat="server" ImageUrl="../images/x1root.gif"
CommandArgument='<%# Eval("Name")+","+Eval("DirectoryName")%>' />
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
</div>
</form>
后台:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using HanSoft.BusinessLogic;
using Insus.NET;
using CAF.DBUtility;
using System.IO;
using System.Data;
using System.Data.SqlClient;
using System.Collections;
using HanSoft.SQLServerDAL; public partial class information_backDB : System.Web.UI.Page
{ protected InsusDateTimeUtility objIdtu = new InsusDateTimeUtility(); InsusIOUtility objIotu = new InsusIOUtility(); protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
Data_Binding();
}
} private void Data_Binding()
{
DirectoryInfo dInfo = new DirectoryInfo(Server.MapPath("~/backSql")); this.gv_DataBasefile.DataSource = dInfo.GetFiles(); this.gv_DataBasefile.DataBind();
} /// <summary>
/// 备份数据库
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Button1_Click(object sender, EventArgs e)
{
try
{
BACKUP();
Label1.Text = "数据库备份成功!";
Data_Binding();
}
catch (Exception ex)
{
Response.Write(ex.Message);
} } /// <summary>
/// 备份数据库方法
/// </summary>
private void BACKUP()
{
string DBname = "1220"; string backUpDBname = DBname + "_" + objIdtu.GetDateTimeMillisecond();//这一步是数据库名+年月日+随机数 objIotu.MakeDirectory(Server.MapPath("~/backSql")); //这一步是在根目录下面生成一个文件夹,名叫 backsql string str_sql = " BACKUP DATABASE [" + DBname + "] TO DISK = '" + Server.MapPath("~/").ToString() + "backSql\\" + backUpDBname + ".bak'"; int i = SqlHelper.ExecuteNonQuery(str_sql);
} /// <summary>
/// 还原数据库
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void gv_DataBasefile_RowCommand(object sender, GridViewCommandEventArgs e)
{
SelectObjectIndexBLL SoIndexBLL = new SelectObjectIndexBLL(); SqlConnection connection = new SqlConnection("Data Source=192.168.1.98;User ID=sa;Password=123"); string path_name = e.CommandArgument.ToString(); string[] array = { }; string[] array1 = { }; array = path_name.Split(','); string dbFileName = array[1].ToString(); array1 = array[0].ToString().Split('_'); string dbName = array1[0].ToString(); SqlCommand command = new SqlCommand("use master;restore database @name from disk=@path WITH REPLACE;", connection); string path = dbFileName + "//" + array[0]; //全路径 command.Parameters.AddWithValue("@name", dbName); //dbName还原目标数据库名 command.Parameters.AddWithValue("@path", path); DataTable dt_spid = SoIndexBLL.GetDataList(" select spid from master..sysprocesses where dbid=db_id('1220') ").Tables[0]; if (dt_spid.Rows.Count > 0)
{
for (int i = 0; i < dt_spid.Rows.Count; i++)
{
string sql = " kill " + Convert.ToString(dt_spid.Rows[i]["spid"]) + " "; //SqlDataAdapter sqldap = new SqlDataAdapter(sql, connection);//--------------1 SqlCommand commd = new SqlCommand(sql, connection);//----------2 connection.Open(); commd.ExecuteReader();//-------------2 connection.Close(); } Label2.Text = " 数据库恢复成功! ";
} connection.Open(); command.ExecuteNonQuery();//-----------------1 connection.Close(); }
}
另外附上两个主键:
InsusDateTimeUtility.dll 和 InsusIOUtility.dll
http://115.com/lb/5lbcqlxnjq4b#InsusDateTimeUtility.dll 115网盘礼包码:5lbcqlxnjq4b
复制链接,接受礼包即可。
asp.net 备份和恢复数据库的更多相关文章
- 13-MySQL DBA笔记-迁移、升级、备份、恢复数据库
第13章 迁移.升级.备份.恢复数据库本章将为读者讲述数据库的各种维护任务:迁移.升级.备份和恢复.因为每个人熟悉的工具不同,其对应的迁移.升级.备份和恢复的方式也都略有不同,本书将尽量对笔者认为最具 ...
- 备份、恢复数据库(Dos命令提示符下)_数据库安装工具_连载_1
Dos命令提示符下: 备份.恢复数据库,是不是很简单啊,是的,当你20年不碰MS SQL,是不是又忘记了呢,答案也许也是吧,^_^虽然在程序中执行SQL代码时,很讨厌那个Go,正如MySQL中那个分号 ...
- C#(asp.net)备份还原mssql数据库代码【转】
采集自互联网,未验证..... 如果我们使用虚拟主机为网站空间,这时如果需要备份和还原msssql数据库是非常麻烦,如果在网站后台管理当中加入对msssql数据库的操纵,可以使我们对数据库的备份和还原 ...
- php 备份和恢复数据库
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 【Oracle】增量备份和全库备份怎么恢复数据库
1差异增量实验示例 1.1差异增量备份 为了演示增量备份的效果,我们在执行一次0级别的备份后,对数据库进行一些改变. 再执行一次1级别的差异增量备份: 执行完1级别的备份后再次对数据库进行更改: 再执 ...
- 【mysql】使用xtrabackup在线增量备份及恢复数据库
一.Percona Xtrabackup 简介 1.Xtrabackup bin目录文件 介绍 1)innobackupex innobackupex 是xtrabackup的一个符号链接 . in ...
- SQL2005中使用backup、restore来备份和恢复数据库
在SQL2005数据库中利用SQL语句进行数据备份与还原: 备份backup:backup database 数据库名称 tO disk = 备份路径例:BACKUP DATABASE test TO ...
- Oracle的常用命令之备份和恢复数据库
1 将数据库TES完全导出,用户名system 密码manager 导出到D:\daochu.dmp中 exp system/manager@TEST file=d:\daochu.dmp 2 将数据 ...
- 怎么用SQL语句备份和恢复数据库?
BACKUP DATABASE "mydb" TO DISK ='C:\mybak.db' with init RESTORE DATABASE "mydb" ...
随机推荐
- 射频识别技术漫谈(3)——能量、调制【worldsing 笔记】
无源和免接触是非接触式IC卡相对于接触式IC卡的两大特点.无源是指卡片上没有电源,免接触是指对卡片的读写操作不必和读写器接触.非接触式智能卡也是IC卡,而卡上的IC即集成电路工作时肯定是需要电源的,卡 ...
- Notepad++的一些常用的快捷键
ctrl+/ 一个一个单词的往后跳Ctrl+H 替换Ctrl+F 查找Ctrl+D 复制当前行到下一行Ctrl+L 删除当前行Ctrl+Shift+F 在文件中找F5 打开run对话框F11 全屏 ...
- PowerDesigner 业务处理模型( BPM )
PowerDesigner 业务处理模型( BPM ) 说明 properties语言文档xmlvalidation数据库 目录(?)[+] 一. BPM 简介 业务处理模型(Busi ...
- 如何在线缩小jpg图片的大小
直接使用在线PS保存成更小格式,即可! 在线PS网址:http://www.webps.cn/ 打开图片 点击保存 直接拖动滑动条就可以改变图片大小
- JQuery.Ajax之错误调试帮助信息介绍
下面是Jquery中AJAX参数详细列表: timeout Number 设置请求超时时间(毫秒).此设置将覆盖全局设置. async Boolean (默认: true) 默认设置下,所有请求均为异 ...
- 64位Ubuntu配置android环境报错(...adb": error=2, 没有那个文件或目录)
Failed to get the adb version: Cannot run program "/home/jayhomzhou/android/android-sdk/platfor ...
- HDU 5289 Assignment(2015 多校第一场二分 + RMQ)
Assignment Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Total ...
- 【49】了解new_handler的行为
1.使用operator new无法获取内存时,对于旧式编译器,会返回一个null指针.对于新式编译器,会抛出一个异常. 2.考虑下面的需求,当operator new 无法获取内存时,程序员期望获得 ...
- 简单详细的OD破解教程
2007-08-04 15:46作者:CCDebuger注:昨天在网上见到了这篇文章,但缺少插图,从另外一篇文章中也看到了类似的的教程文章,里面的插图质量实在不敢恭维.在一个论坛中正好下载了文章中所介 ...
- Windows下python环境变量配置
默认情况下,在windows下安装python之后,系统并不会自动添加相应的环境变量.此时不能在命令行直接使用python命令. 1. 首先需要在系统中注册python环境变量:假设python的安装 ...