當使用Interop.SQLDMO.dll備份SQL Server 2008的數據庫時出現以上錯誤,
但是備份SQL Server 2005數據庫,卻沒有問題。
由于需要在程序中加上數據庫的備份與恢復功能,所以需要使用到SQLDMO。
但在系統中沒有找到SQLDMO.dll,然后谷歌之,發現msdn上這樣說:
“后續版本的 Microsoft SQL Server 將刪除該功能。”
于是繼續谷歌,發現需要安裝Microsoft SQL Server 2005 向后兼容組件
這里下載:
Microsoft SQL Server 2005 向后兼容組件
SQL Server 向后兼容包中包含最新版本的 Data Transformation Services 2000 運行庫 (DTS)、SQL 分布式管理對象 (SQL-DMO)、決策支持對象 (DSO) 和 SQL 虛擬設備接口 (SQLVDI)。為了與 SQL Server 2005 和 SQL Server 2008 都兼容,這些版本已進行了更新,并且包含 SQL Server 2000 SP4 和 SQL Server 2005 SP2 提供的所有修補程序。
用戶:客戶、合作伙伴、開發人員
X86 包 (SQLServer2005_BC.msi) – 11273 KB
X64 包 (SQLServer2005_BC.msi) – 18569 KB
安裝完成后在c#項目引用中加上SQLDMO.dll即可
SQLDMO.dll在$Program Files$Microsoft SQL Server80ToolsBinn這個目錄里。
在恢復數據庫時需要注意的是,先將左右鏈接到數據庫的進程kill掉,才能恢復。
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() == “CgRecord”.ToUpper())
oSQLServer.KillProcess(lPID);
}
SQLDMO(SQL Distributed Management Objects,SQL分布式管理對象)封裝 Microsoft SQL Server 2000 數據庫中的對象。SQL-DMO 允許用支持自動化或 COM 的語言編寫應用程序,以管理 SQL Server 安裝的所有部分。SQL-DMO 是 SQL Server 2000 中的 SQL Server 企業管理器所使用的應用程序接口 (API);因此使用 SQL-DMO 的應用程序可以執行 SQL Server 企業管理器執行的所有功能。
SQL-DMO 用于必須包含 SQL Server 管理的任何自動化或 COM 應用程序,例如:
1.封裝 SQL Server 作為自己的數據存儲并想盡量減少用戶的 SQL Server 管理任務的應用程序。
2.在程序本身并入了專門的管理邏輯的應用程序。
3.想在自己的用戶界面中集成 SQL Server 管理任務的應用程序。
SQLDMO對象來自SQLDMO.dll,SQLDMO.dll是隨SQL Server2000一起發布的。SQLDMO.dll自身是一個COM對象,因此,在你的.NET項目里必須先引用它。
private void Button3_Click(object sender, System.EventArgs e)
{
//引用SQLDMO.dll,SQLDMO由Microsoft SQL Server自帶的SQLDMO.dll提供,SQLDMO.dll是一個COM對象
SQLDMO.Backup backup=new SQLDMO.BackupClass();
SQLDMO.SQLServer sqlserver=new SQLDMO.SQLServerClass();
sqlserver.LoginSecure=false;
sqlserver.Connect("localhost","sa","1");
backup.Action=SQLDMO.SQLDMO_BACKUP_TYPE.SQLDMOBackup_Database;
backup.Database="userdb";
backup.Files=@"E:/Project/meng/data/userdb.bak";
backup.BackupSetName="userdb";
backup.BackupSetDescription="數據庫備份";
backup.Initialize=true;
backup.SQLBackup(sqlserver);
}
private void Button4_Click(object sender, System.EventArgs e)
{
SQLDMO.Restore restore=new SQLDMO.RestoreClass();
SQLDMO.SQLServer sqlserver=new SQLDMO.SQLServerClass();
sqlserver.LoginSecure=false;
sqlserver.Connect("192.168.19.25","sa","sa"); restore.Action=SQLDMO.SQLDMO_RESTORE_TYPE.SQLDMORestore_Database;
restore.Database="userdb";
restore.Files=@"E:/Project/meng/data/userdb.bak";
restore.BackupSetName="userdb";
restore.FileNumber=1;
restore.SQLRestore(sqlserver);
}
//得到指定SQL服務器所有數據庫的列表
public ArrayList GetDataBaseList(string ServerName,string UserName,string Pwd)
{
ArrayList list = new ArrayList() ;
SQLDMO.Application sqlApp = new SQLDMO.Application() ;
SQLDMO.SQLServer oServer = new SQLDMO.SQLServer() ;
oServer.Connect(ServerName,UserName,Pwd);
foreach(SQLDMO.Database db in oServer.Databases)
{
if((db.Name!=null) && (db.SystemObject == false))
list.Add(db.Name);
}
return list ;
}
//得到SQL服務器的列表
public ArrayList GetSqlServerList()
{
ArrayList list = new ArrayList() ;
SQLDMO.Application sqlApp = new SQLDMO.Application();
SQLDMO.NameList ServerName = sqlApp.ListAvailableSQLServers();
for(int i=0;i<ServerName.Count;i++)
{
list.Add(ServerName.Item(i+1));
}
return list;
}