sqlserver備份還原數(shù)據(jù)庫功能封裝分享
using System;
using SQLDMO;
namespace EDTBackupTool
{
/// <summary>
/// Backup 的摘要說明。
/// </summary>
public class SQLTools
{
public static bool Backup(string backfile){
try
{
SQLDMO.Backup backup = new BackupClass();
SQLDMO.SQLServer server = new SQLServerClass();
server.LoginSecure = true;
server.Connect(ClientCommon.CommonFunctions.DataSource,"sa","");
backup.Action = SQLDMO.SQLDMO_BACKUP_TYPE.SQLDMOBackup_Database;
backup.Database = ClientCommon.CommonFunctions.Catalog;
backup.Files =backfile;
backup.BackupSetName =ClientCommon.CommonFunctions.Catalog;
backup.BackupSetDescription = "數(shù)據(jù)庫備份";
backup.Initialize = true;
backup.SQLBackup(server);
return true;
}
catch(Exception ex){
ClientCommon.ExceptionRecorder.Record(ex);
return false;
}
}
public static bool RestoreDB(string strFileName)
{
SQLDMO.SQLServer svr = new SQLDMO.SQLServerClass() ;
try
{
svr.LoginSecure=true;
svr.Connect(ClientCommon.CommonFunctions.DataSource,"sa","") ;
SQLDMO.QueryResults qr = svr.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() == ClientCommon.CommonFunctions.Catalog)
{
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() == ClientCommon.CommonFunctions.Catalog)
{
svr.KillProcess(lPID) ;
}
}
SQLDMO.Restore res = new SQLDMO.RestoreClass() ;
res.Action = 0 ;
res.Files = strFileName ;
res.Database = ClientCommon.CommonFunctions.Catalog ;
res.ReplaceDatabase = true ;
res.SQLRestore(svr) ;
return true ;
}
catch
{
return false;
}
finally
{
svr.DisConnect() ;
}
}
}
}
- SQL Server 數(shù)據(jù)庫備份和還原認識和總結(jié) (一)
- sql server 2005數(shù)據(jù)庫備份還原圖文教程
- sql server 2000數(shù)據(jù)庫備份還原的圖文教程
- SQL Server 2008 備份數(shù)據(jù)庫、還原數(shù)據(jù)庫的方法
- SqlServer高版本數(shù)據(jù)備份還原到低版本
- sqlserver數(shù)據(jù)庫高版本備份還原為低版本的方法
- SQL Server2012數(shù)據(jù)庫備份和還原的教程
- SqlServer數(shù)據(jù)庫備份與還原的實現(xiàn)步驟
- SQL?Server數(shù)據(jù)庫的備份和還原保姆級教程

