asp.net实现数据库备份还原功能

  1. -- 备份数据库
  2. backup database db_CSManage to disk=‘c:\backup.bak‘
  3. -- 还原数据库,必须先备份该数据库的日志文件到原先的备份文件中
  4. backup log db_CSManage to disk=‘c:\backup.bak‘
  5. restore database db_CSManage from disk=‘c:\backup.bak‘

其中db_CSManage是数据库名称,disk后的路径即是备份文件存储的路径。 
知道了SQL语句,那么在.NET代码中就容易多了,备份的.NET代码如下:

  1. try
  2. {
  3. if (txtPath.Text != "" && txtName122.Text != "")
  4. {
  5. getSqlConnection geCon = new getSqlConnection();
  6. SqlConnection con = geCon.GetCon();
  7. string strBacl = "backup database db_CSManage to disk=‘" + txtPath.Text.Trim() + "\\" + txtName.Text.Trim() + ".bak‘";
  8. SqlCommand Cmd = new SqlCommand(strBacl, con);
  9. if (Cmd.ExecuteNonQuery() != 0)
  10. {
  11. MessageBox.Show("数据备份成功!", "提示框", MessageBoxButtons.OK, MessageBoxIcon.Information);
  12. this.Close();
  13. }
  14. else
  15. {
  16. MessageBox.Show("数据备份失败!", "提示框", MessageBoxButtons.OK, MessageBoxIcon.Information);
  17. }
  18. }
  19. else
  20. {
  21. MessageBox.Show("请填写备份的正确位置及文件名!", "提示框", MessageBoxButtons.OK, MessageBoxIcon.Information);
  22. }// end
  23. }
  24. catch (Exception ee)
  25. {
  26. MessageBox.Show(ee.Message.ToString());
  27. }

以下是还原数据库的代码,在示例中发现开头得先删除与该数据库相关的进程,然后在还原之前得先把数据库日志备份到开始的备份文件中,然后才还原备份文件,要不然会出错的,代码如下:

  1. if (textPaht.Text != "")
  2. {
  3. getSqlConnection geCon = new getSqlConnection();
  4. SqlConnection con = geCon.GetCon();
  5. if (con.State == ConnectionState.Open)
  6. {
  7. con.Close();
  8. }
  9. string DateStr = "Data Source=niunan\\sqlexpress;Database=master;User id=sa;PWD=123456";
  10. SqlConnection conn = new SqlConnection(DateStr);
  11. conn.Open();
  12. //-------------------杀掉所有连接 db_CSManage 数据库的进程--------------
  13. string strSQL = "select spid from master..sysprocesses where dbid=db_id( ‘db_CSManage‘) ";
  14. SqlDataAdapter Da = new SqlDataAdapter(strSQL, conn);
  15. DataTable spidTable = new DataTable();
  16. Da.Fill(spidTable);
  17. SqlCommand Cmd = new SqlCommand();
  18. Cmd.CommandType = CommandType.Text;
  19. Cmd.Connection = conn;
  20. for (int iRow = 0; iRow <= spidTable.Rows.Count - 1; iRow++)
  21. {
  22. Cmd.CommandText = "kill " + spidTable.Rows[iRow][0].ToString();   //强行关闭用户进程
  23. Cmd.ExecuteNonQuery();
  24. }
  25. conn.Close();
  26. conn.Dispose();
  27. //--------------------------------------------------------------------
  28. SqlConnection sqlcon = new SqlConnection(DateStr);
  29. sqlcon.Open();
  30. string sql = "backup log db_CSManage to disk=‘" + textPaht.Text.Trim() + "‘ restore database db_CSManage from disk=‘" + textPaht.Text.Trim() + "‘";
  31. SqlCommand sqlCmd = new SqlCommand(sql, sqlcon);
  32. sqlCmd.ExecuteNonQuery();
  33. sqlCmd.Dispose();
  34. sqlcon.Close();
  35. sqlcon.Dispose();
  36. MessageBox.Show("数据还原成功!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  37. MessageBox.Show("为了必免数据丢失,在数据库还原后将关闭整个系统。");
  38. Application.Exit();
  39. }
  40. else
  41. {
  42. MessageBox.Show("请选择备份文件!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Warning);
  43. }

asp.net实现数据库备份还原功能

时间: 2024-10-15 00:35:02

asp.net实现数据库备份还原功能的相关文章

SQL server数据库备份还原问题备忘(亲测有效)

问题一:SQL server数据库备份还原方法 http://www.cnblogs.com/zgqys1980/archive/2012/07/04/2576382.html 问题二:无法执行 BACKUP LOG,因为当前没有数据库备份 http://blog.csdn.net/aojiancc2/article/details/46316451 问题三:还原数据库失败 备份集中数据库备份与现有数据库不同 http://jingyan.baidu.com/article/fb48e8be52

织梦数据库备份还原

[功能描述]系统数据库备份还原.[操作说明]后台登陆-系统-数据库备份/还原.[应用实例]进入数据库备份还原操作界面备份:这里可以全选或选择部分表进行备份,指定备份数据格式我们一般为默认,分卷大小一般为2048,备份表结构信息默认打勾,如只需要备份数据时,可以不选择.我们点击提交按钮.这里显示备份进度,备份完成后会提示“完成所有数据备份”!我们可以点击数据还原进行查看.恢复:进入备份还原操作界面,点击数据还原,出现我们备份的数据信息这里我们同样可以还原某一个表或全部,我们点开始还原数据.这时还原

MSSQL2008数据库备份还原和数据恢复

原文:MSSQL2008数据库备份还原和数据恢复   序言 一直想写一篇关于数据库备份与恢复的文章,但基于能力的有限对数据库认知的有限怕不足以准确的表达,最后思考很久还是决定把自己的一些理解写出来供大家参考,也是为了回报自己:出于能力及语言表达能力的有限还望大家包含,如果里面有说的不对的地方还望大家及时提出.好及时修改不至于错误的引导他人. 认识数据库备份和事务日志备份 数据库备份与日志备份是数据库维护的日常工作,备份的目的是在于当数据库出现故障或者遭到破坏时可以根据备份的数据库及事务日志文件还

数据库备份还原

http://www.cnblogs.com/brucexuyg/archive/2012/06/22/2558755.html 以表”Table”为例:如类型是MyISAM, 数据文件则以”Table.frm””Table.MYD””Table.MYI””三个文件存储于”/data/$databasename/”目录中.如类型是InnoDB, 数据文件则存储在”$innodb_data_home_dir/″中的ibdata1文件中(一般情况),结构文件存在于table_name.frm中.My

第二百九十节,MySQL数据库-MySQL命令行导出导入数据库,数据库备份还原

MySQL命令行导出导入数据库,数据库备份还原 MySQL命令行导出数据库:1,进入MySQL目录下的bin文件夹:cd MySQL中到bin文件夹的目录如我输入的命令行:cd C:\Program Files\MySQL\MySQL Server 4.1\bin(或者直接将windows的环境变量path中添加该目录) 2,导出数据库:mysqldump -u 用户名 -p 数据库名 > 导出的文件名 如我输入的命令行:mysqldump -u root -p news > news.sql

学习笔记(十三)——数据库备份还原的知识点与注意事项

学习笔记(十三)——数据库备份还原的知识点与注意事项 一.备份还原基本概念 1.  完整备份:完整备份因为需要备份的数据量大,所以需要在空闲时间进行,并且定期进行. 2.  日志备份:日志备份的数据量小,备份时间为上一次备份到本次本分期间的数据,每天都可以进行备份,或者每小时都可以进行备份,据所需备份. 3.  增量备份(差异备份):只备份修改过的数据,与每小时进行的日志备份配合使用,效率更高. 二.备份设备 1.          在进行备份数据的保存时,需要输入的文件路径很长,并且每次都要输

MYSQL数据库备份还原

MYSQL数据库备份还原 一.  数据库备份 备份数据是数据库管理最常用的操作.为了保证数据库中数据的安全,数据管理员需要定期地进行数据备份.一旦数据库遭到破坏,即可通过备份的文件来还原.因此,数据备份是很重要的工作. 1.使用mysqldump 命令备份 mysqldump 命令可以将数据库中的数据备份成一个文本文件.表的结构和表中的数据将存储在生成的文本文件中.mysqldump 命令的工作原理很简单: 它先查出需要备份的表的结构,再在文本文件中生成一个CREATE 语句,然后将表中的所有记

达梦数据库备份还原

1.数据库备份还原 --备份 backup database full to BAK201812050 bakfile 'E:\soft\dmdbms\data\DAMENG\bak\BAK201812050.bak' compressed; --还原 dmrestore ini_path=E:\dmdbms\data\DAMENG\dm.ini file=E:\dmdbms\data\DAMENG\bak\BAK201812050.bak 原文地址:https://www.cnblogs.co

java sql编辑器 动态报表 数据库备份还原 quartz定时任务调度 自定义表单 java图片爬虫

获取[下载地址]   QQ: 313596790   [免费支持更新] 三大数据库 mysql  oracle  sqlsever   更专业.更强悍.适合不同用户群体 [新录针对本系统的视频教程,手把手教开发一个模块,快速掌握本系统] A 集成代码生成器(开发利器)+快速构建表单;            QQ:313596790 freemaker模版技术 ,0个代码不用写,生成完整的一个模块,带页面.建表sql脚本,处理类,service等完整模块 B 集成阿里巴巴数据库连接池druid;