C#备份数据库文件

c#备份数据库文件完整代码

sqlServer 存储过程:

复制代码
USE [PSIDBase]
GO
/****** Object:  StoredProcedure [dbo].[sp_BackupDB]    Script Date: 2023/8/31 16:49:02 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
 ALTER procedure [dbo].[sp_BackupDB]
     @savePath nvarchar(4000) -- 备份数据库保存位置(目录)   
     ,@dbName nvarchar(4000) -- 需要进行备份的数据库
     ,@bakName nvarchar(4000) -- 备份文件的名称(不含扩展名)
 as begin
     declare @sql nvarchar(4000)
     /* 验证路径 */
     if(charindex('/',reverse(@savePath))!=1) begin
         set @savePath=@savePath+'/'
     end
     /* 拼SQL并执行 */
     set @sql='backup database '+@dbName+' to disk='''+@savePath+@bakName+'.bak'''
     exec sp_executesql @sql
     
     /* 返回执行结果(1=成功,0=失败) */
     if(@@error=0) begin
         return 1
     end
     return 0
 end

App.config添加配置项

复制代码
<?xml version="1.0" encoding="utf-8"?>
<configuration>
    <startup> 
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.8"/>
    </startup>
  <connectionStrings>
    <add name="connStr" connectionString="server=PC-20191008BGNB\SQLEXPRESS;database=***;uid=**;pwd=***;" providerName="System.Data.SqlClient"/>
  </connectionStrings>
	<appSettings>
		<add key="DbName" value="PSIDBase"/>
	</appSettings>
</configuration>

DAL文件:

复制代码
 /// <summary>
 /// 备份数据
 /// </summary>
 /// <param name="path"></param>
 /// <param name="dbName"></param>
 /// <param name="backupName"></param>
 /// <returns></returns>
 public int BackupData(string path, string dbName, string backupName)
 {
     SqlParameter[] paras =
     {
         new SqlParameter("@savePath",path),
         new SqlParameter("@dbName",dbName),
         new SqlParameter("@bakName",backupName),
         new SqlParameter("@return",SqlDbType.Int,4)
     };
     paras[3].Direction = ParameterDirection.ReturnValue;//返回值参数
     SqlHelper.ExecuteNonQuery("sp_BackupDB", 2, paras);
     return paras[3].Value.GetInt();
 }

BLL:

复制代码
/// <summary>
/// 备份数据
/// </summary>
/// <param name="path"></param>
/// <returns></returns>
public bool BackupData(string path)
{
    bool bl = false;
    string dbName = ConfigurationManager.AppSettings["DbName"].ToString();
    string backupName = dbName + DateTime.Today.ToString("yyyyMMdd");
    int reVal = sysDAL.BackupData(path, dbName, backupName);
    bl = reVal == 1 ? true : false;
    return bl;
}

窗体调用:

复制代码
using PSI.BLL;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using WinPSI.Common;

namespace WinPSI.SM
{
    public partial class FrmBackUpData : Form
    {
        public FrmBackUpData()
        {
            InitializeComponent();
        }
        private Verify verify = new Verify();

        private void btnCancel_Click(object sender, EventArgs e)
        {
            this.Close();
        }

        private void FrmBackUpData_Load(object sender, EventArgs e)
        {
            txtPath.Clear();
        }
        /// <summary>
        /// 选择备份位置
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btnChoose_Click(object sender, EventArgs e)
        {
            FolderBrowserDialog ofd = new FolderBrowserDialog();
            if(ofd.ShowDialog()==DialogResult.OK)
            {
                txtPath.Text = ofd.SelectedPath;
            }
        }
        private void btnOK_Click(object sender, EventArgs e)
        {
            string path = txtPath.Text.Trim();
            if (string.IsNullOrEmpty(path))
            {
                MsgBoxHelper.MsgErrorShow("请选择备份文件存放的位置!");
                return;
            }
            if (MsgBoxHelper.MsgBoxConfirm("备份数据", "您确定要备份数据库吗?") == DialogResult.Yes)
            {
                SysBLL sysBLL = new SysBLL();
                bool bl = sysBLL.BackupData(path);
                if (bl)
                {
                    MsgBoxHelper.MsgBoxShow("备份数据", "系统数据备份完毕!");
                }
                else
                {
                    MsgBoxHelper.MsgErrorShow("数据备份失败!");
                    return;
                }
            }
        }
    }
}
相关推荐
uElY ITER2 小时前
Spring全家桶简介
java·后端·spring
lay_liu8 小时前
springboot 文件下载
java·spring boot·后端
武藤一雄12 小时前
C# 异步回调与等待机制
前端·microsoft·设计模式·微软·c#·.netcore
2601_9498161612 小时前
spring.profiles.active和spring.profiles.include的使用及区别说明
java·后端·spring
helx8214 小时前
SpringBoot实战(三十二)集成 ofdrw,实现 PDF 和 OFD 的转换、SM2 签署OFD
spring boot·后端·pdf
rOuN STAT14 小时前
Skywalking介绍,Skywalking 9.4 安装,SpringBoot集成Skywalking
spring boot·后端·skywalking
乱蜂朝王15 小时前
使用 C# 和 ONNX Runtime 部署 PaDiM 异常检测模型
开发语言·c#
bilI LESS16 小时前
Spring Boot接收参数的19种方式
java·spring boot·后端
web前端进阶者16 小时前
Rust初学知识点快速记忆
开发语言·后端·rust
JosieBook17 小时前
【C#】VS中的 跨线程调试异常:CrossThreadMessagingException
开发语言·c#