.Net下的数据备份和还原
2006-05-22 09:24
381 查看
数据库:SQL Server ;引用SQLDMO
◆数据备份 :
/// <summary>
/// 备份数据库
/// </summary>
private void btnBackUp_Click(object sender, System.EventArgs e)
{
this.Cursor = Cursors.WaitCursor;
this.label1.Text = " 正在进行档案库的数据备份,这可能需要几秒到几十的时间,请稍候...";
this.label1.Visible = true;
this.label1.Refresh();
this.pBar1.Visible = true;
//------------------------------------------------------------------------------------
string selfName = “D:/NorthwindBak“;
string deviceName = “NorthwindBak“;
string remark = "备份测试";
//◆数据备份:
SQLDMO.Backup oBackup = new SQLDMO.BackupClass();
SQLDMO.SQLServer oSQLServer = new SQLDMO.SQLServerClass();
oBackup.Action = 0 ;
oBackup.Initialize = true ;
SQLDMO.BackupSink_PercentCompleteEventHandler pceh = new SQLDMO.BackupSink_PercentCompleteEventHandler(Step);
oBackup.PercentComplete += pceh;
try
{
oSQLServer.LoginSecure = false;
oSQLServer.Connect(Common.MySettings.SqlServerName, "sa", "");
oBackup.Action = SQLDMO.SQLDMO_BACKUP_TYPE.SQLDMOBackup_Database;
oBackup.Database = "Northwind";//数据库名
oBackup.Files = selfName;//文件路径
oBackup.BackupSetName = deviceName;//备份名称
oBackup.BackupSetDescription = remark;//备份描述
oBackup.Initialize = true;
oBackup.SQLBackup(oSQLServer);
}
catch(System.Exception ex)
{
Common.ShowMsg("数据备份失败:/n" + ex.ToString());
}
finally
{
oSQLServer.DisConnect();
}
//------------------------------------------------------------------------------------
this.label1.Visible = false;
this.pBar1.Visible = false;
this.Cursor = Cursors.Default;
}
/// <summary>
/// 显示备份进度条
/// </summary>
private void Step(string message,int percent)
{
this.pBar1.Value = percent ;
}
◆数据还原 :
/// <summary>
/// 还原数据库
/// </summary>
private void btnRestore_Click(object sender, System.EventArgs e)
{
this.Cursor = Cursors.WaitCursor;
this.label1.Text = " 正在进行档案库的数据还原,这可能需要几秒到几十的时间,请稍候...";
this.label1.Visible = true;
this.label1.Refresh();
this.pBar1.Visible = true;
//------------------------------------------------------------------------------------
string fileName = "NorthwindBak";
string filePath = "D:/NorthwindBak";
string remark = "备份测试";
SQLDMO.Restore oRestore = new SQLDMO.RestoreClass();
SQLDMO.SQLServer oSQLServer = new SQLDMO.SQLServerClass();
oRestore.Action = 0 ;
SQLDMO.RestoreSink_PercentCompleteEventHandler pceh = new SQLDMO.RestoreSink_PercentCompleteEventHandler(Step);
oRestore.PercentComplete += pceh;
try
{
oSQLServer.Connect(Common.MySettings.SqlServerName, "sa", "");
SQLDMO.QueryResults qr = oSQLServer.EnumProcesses(-1) ;
int iColPIDNum = -1 ;
int iColDbName = -1 ;
//杀死其它的连接进程
for(int i=1;i<=qr.Columns;i++)
{
string strName = qr.get_ColumnName(i) ;
if (strName.ToUpper().Trim() == "SPID")
{
iColPIDNum = i ;
}
else if (strName.ToUpper().Trim() == "DBNAME")
{
iColDbName = i ;
}
if (iColPIDNum != -1 && iColDbName != -1)
break ;
}
for(int i=1;i<=qr.Rows;i++)
{
int lPID = qr.GetColumnLong(i,iColPIDNum) ;
string strDBName = qr.GetColumnString(i,iColDbName) ;
if (strDBName.ToUpper() == "Northwind".ToUpper())
oSQLServer.KillProcess(lPID) ;
}
oRestore.Action = SQLDMO.SQLDMO_RESTORE_TYPE.SQLDMORestore_Database;
oRestore.Database = "Northwind";
oRestore.Files = filePath;
oRestore.FileNumber = 1;
oRestore.ReplaceDatabase = true;
oRestore.SQLRestore(oSQLServer);
}
catch(System.Exception ex)
{
Common.ShowMsg("数据还原失败:/n" + ex.ToString());
}
finally
{
oSQLServer.DisConnect();
}
//------------------------------------------------------------------------------------
this.label1.Visible = false;
this.pBar1.Visible = false;
this.Cursor = Cursors.Default;
}
/// <summary>
/// 显示还原进度条
/// </summary>
private void Step(string message,int percent)
{
this.pBar1.Value = percent ;
}
◆数据备份 :
/// <summary>
/// 备份数据库
/// </summary>
private void btnBackUp_Click(object sender, System.EventArgs e)
{
this.Cursor = Cursors.WaitCursor;
this.label1.Text = " 正在进行档案库的数据备份,这可能需要几秒到几十的时间,请稍候...";
this.label1.Visible = true;
this.label1.Refresh();
this.pBar1.Visible = true;
//------------------------------------------------------------------------------------
string selfName = “D:/NorthwindBak“;
string deviceName = “NorthwindBak“;
string remark = "备份测试";
//◆数据备份:
SQLDMO.Backup oBackup = new SQLDMO.BackupClass();
SQLDMO.SQLServer oSQLServer = new SQLDMO.SQLServerClass();
oBackup.Action = 0 ;
oBackup.Initialize = true ;
SQLDMO.BackupSink_PercentCompleteEventHandler pceh = new SQLDMO.BackupSink_PercentCompleteEventHandler(Step);
oBackup.PercentComplete += pceh;
try
{
oSQLServer.LoginSecure = false;
oSQLServer.Connect(Common.MySettings.SqlServerName, "sa", "");
oBackup.Action = SQLDMO.SQLDMO_BACKUP_TYPE.SQLDMOBackup_Database;
oBackup.Database = "Northwind";//数据库名
oBackup.Files = selfName;//文件路径
oBackup.BackupSetName = deviceName;//备份名称
oBackup.BackupSetDescription = remark;//备份描述
oBackup.Initialize = true;
oBackup.SQLBackup(oSQLServer);
}
catch(System.Exception ex)
{
Common.ShowMsg("数据备份失败:/n" + ex.ToString());
}
finally
{
oSQLServer.DisConnect();
}
//------------------------------------------------------------------------------------
this.label1.Visible = false;
this.pBar1.Visible = false;
this.Cursor = Cursors.Default;
}
/// <summary>
/// 显示备份进度条
/// </summary>
private void Step(string message,int percent)
{
this.pBar1.Value = percent ;
}
◆数据还原 :
/// <summary>
/// 还原数据库
/// </summary>
private void btnRestore_Click(object sender, System.EventArgs e)
{
this.Cursor = Cursors.WaitCursor;
this.label1.Text = " 正在进行档案库的数据还原,这可能需要几秒到几十的时间,请稍候...";
this.label1.Visible = true;
this.label1.Refresh();
this.pBar1.Visible = true;
//------------------------------------------------------------------------------------
string fileName = "NorthwindBak";
string filePath = "D:/NorthwindBak";
string remark = "备份测试";
SQLDMO.Restore oRestore = new SQLDMO.RestoreClass();
SQLDMO.SQLServer oSQLServer = new SQLDMO.SQLServerClass();
oRestore.Action = 0 ;
SQLDMO.RestoreSink_PercentCompleteEventHandler pceh = new SQLDMO.RestoreSink_PercentCompleteEventHandler(Step);
oRestore.PercentComplete += pceh;
try
{
oSQLServer.Connect(Common.MySettings.SqlServerName, "sa", "");
SQLDMO.QueryResults qr = oSQLServer.EnumProcesses(-1) ;
int iColPIDNum = -1 ;
int iColDbName = -1 ;
//杀死其它的连接进程
for(int i=1;i<=qr.Columns;i++)
{
string strName = qr.get_ColumnName(i) ;
if (strName.ToUpper().Trim() == "SPID")
{
iColPIDNum = i ;
}
else if (strName.ToUpper().Trim() == "DBNAME")
{
iColDbName = i ;
}
if (iColPIDNum != -1 && iColDbName != -1)
break ;
}
for(int i=1;i<=qr.Rows;i++)
{
int lPID = qr.GetColumnLong(i,iColPIDNum) ;
string strDBName = qr.GetColumnString(i,iColDbName) ;
if (strDBName.ToUpper() == "Northwind".ToUpper())
oSQLServer.KillProcess(lPID) ;
}
oRestore.Action = SQLDMO.SQLDMO_RESTORE_TYPE.SQLDMORestore_Database;
oRestore.Database = "Northwind";
oRestore.Files = filePath;
oRestore.FileNumber = 1;
oRestore.ReplaceDatabase = true;
oRestore.SQLRestore(oSQLServer);
}
catch(System.Exception ex)
{
Common.ShowMsg("数据还原失败:/n" + ex.ToString());
}
finally
{
oSQLServer.DisConnect();
}
//------------------------------------------------------------------------------------
this.label1.Visible = false;
this.pBar1.Visible = false;
this.Cursor = Cursors.Default;
}
/// <summary>
/// 显示还原进度条
/// </summary>
private void Step(string message,int percent)
{
this.pBar1.Value = percent ;
}
相关文章推荐
- ASP.NET备份数据与还原数据,解决数据库正在使用的问题
- Net下的数据备份和还原
- asp.net备份和还原access数据
- Asp.net 不使用SQLDMO实现数据库备份和还原
- 数据库备份与还原(ASP.NET)
- linux数据误删后,灾难性数据备份与数据还原
- .Net下的数据备份和还原
- MySQL 数据备份和还原 详解
- [Unity3D]AssetServer服务器迁移数据备份还原
- 数据备份与还原
- DHCP服务器数据备份以及还原
- mysql学习笔记--数据备份与还原
- mysql 数据还原时,备份的SQL文件过大导致的错误,解决办法!
- 为 Windows Server 2003 备份和还原数据
- Xtrabackup数据库的数据备份和还原
- Xtrabackup数据库的数据备份和还原
- Xtrabackup数据库的数据备份和还原
- 如何将sql2000数据备份文件(,bak)还原为sql2005文件
- MySQL数据的备份与还原
- linux 平台下 postgres 使用 (安装 启动 关闭 数据备份 还原)