观看了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 备份和恢复数据库的更多相关文章

  1. 13-MySQL DBA笔记-迁移、升级、备份、恢复数据库

    第13章 迁移.升级.备份.恢复数据库本章将为读者讲述数据库的各种维护任务:迁移.升级.备份和恢复.因为每个人熟悉的工具不同,其对应的迁移.升级.备份和恢复的方式也都略有不同,本书将尽量对笔者认为最具 ...

  2. 备份、恢复数据库(Dos命令提示符下)_数据库安装工具_连载_1

    Dos命令提示符下: 备份.恢复数据库,是不是很简单啊,是的,当你20年不碰MS SQL,是不是又忘记了呢,答案也许也是吧,^_^虽然在程序中执行SQL代码时,很讨厌那个Go,正如MySQL中那个分号 ...

  3. C#(asp.net)备份还原mssql数据库代码【转】

    采集自互联网,未验证..... 如果我们使用虚拟主机为网站空间,这时如果需要备份和还原msssql数据库是非常麻烦,如果在网站后台管理当中加入对msssql数据库的操纵,可以使我们对数据库的备份和还原 ...

  4. php 备份和恢复数据库

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  5. 【Oracle】增量备份和全库备份怎么恢复数据库

    1差异增量实验示例 1.1差异增量备份 为了演示增量备份的效果,我们在执行一次0级别的备份后,对数据库进行一些改变. 再执行一次1级别的差异增量备份: 执行完1级别的备份后再次对数据库进行更改: 再执 ...

  6. 【mysql】使用xtrabackup在线增量备份及恢复数据库

    一.Percona Xtrabackup 简介 1.Xtrabackup  bin目录文件 介绍 1)innobackupex innobackupex 是xtrabackup的一个符号链接 . in ...

  7. SQL2005中使用backup、restore来备份和恢复数据库

    在SQL2005数据库中利用SQL语句进行数据备份与还原: 备份backup:backup database 数据库名称 tO disk = 备份路径例:BACKUP DATABASE test TO ...

  8. Oracle的常用命令之备份和恢复数据库

    1 将数据库TES完全导出,用户名system 密码manager 导出到D:\daochu.dmp中 exp system/manager@TEST file=d:\daochu.dmp 2 将数据 ...

  9. 怎么用SQL语句备份和恢复数据库?

    BACKUP DATABASE "mydb" TO DISK ='C:\mybak.db' with init RESTORE DATABASE "mydb" ...

随机推荐

  1. UIKit: UIResponder(转自南峰子博客)

    有问题可以加本人QQ:564702640(验证:博客园) 我们的App与用户进行交互,基本上是依赖于各种各样的事件.例如,用户点击界面上的按钮,我们需要触发一个按钮点击事件,并进行相应的处理,以给用户 ...

  2. 关于 android的 渲染器 Shader

    因为公司在 自定义的画图上面比较苛刻(各种要求= =),最后又是改来改去的.反正是 Shader起到很大作用,特此记录一下下.在achartengine的基础上没有能满足他们= = androd 提供 ...

  3. PHOTOSHOP 中画笔工具和铅笔工具的一个小小差别

    今天在作图的时候偶然发现的一个以前并没有在意画笔和铅笔的小小区别,情况是这样的,我在做图像处理,需要一个单像素的闭合曲线灰度图来做实验,然后用画笔工具把直径调到1之后去作图,放大之后发现,跟预想的结果 ...

  4. 防止跨域(jsonp详解)

    详见:http://www.cnblogs.com/lemontea/archive/2012/12/11/2812268.html $("#getJsonpByJquery"). ...

  5. 在线性级别时间内找出无序序列中的第k个元素

    在一个无序序列中找出第k个元素,对于k很小或者很大时可以采取特殊的方法,比如用堆排序来实现 .但是对于与序列长度N成正比的k来说,就不是一件容易的事了,可能最容易想到的就是先将无序序列排序再遍历即可找 ...

  6. hdu 5432 Pyramid Split 二分

    Pyramid Split Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://bestcoder.hdu.edu.cn/contests/conte ...

  7. jquery实现无缝滚动

    //点击上一页 $('.pointLeft').click(function() { if (prevAllow) { prevAllow = false; scrollUlLeft = scroll ...

  8. mysqldump 的一些使用参数

    备份数据库#mysqldump 数据库名 >数据库备份名 #mysqldump -A -u用户名 -p密码 数据库名>数据库备份名 #mysqldump -d -A --add-drop- ...

  9. dynamic_cast用法

    dynamic_cast < type-id > ( expression ) 该运算符把expression转换成type-id类型的对象.Type-id必须是类的指针.类的引用或者vo ...

  10. 有关于Algorithm的基础介绍

    Niklaus Wirth:Algorithm + Data Structures = Programs 这句话呢,觉得很正确,算法和程序是不同的概念,算法的思想呢有递推,枚举,分治,贪婪,试探法,模 ...