狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開(kāi)發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

SQL Server 2008 中使用SQLDMO備份數(shù)據(jù)、還原數(shù)據(jù)等

admin
2018年1月31日 0:6 本文熱度 7117

SQL Server 異常 COM 類(lèi)工廠中CLSID 為 {10021F00-E260-11CF-AE68-00AA004A34D5} 的組件時(shí)失敗,原因是出現(xiàn)以下錯(cuò)誤: 80070005


當(dāng)使用Interop.SQLDMO.dll備份SQL Server 2008的數(shù)據(jù)庫(kù)時(shí)出現(xiàn)以上錯(cuò)誤,

但是備份SQL Server 2005數(shù)據(jù)庫(kù),卻沒(méi)有問(wèn)題。


以下內(nèi)容摘自:http://blog.csdn.net/nodbrag/article/details/7980763

由于需要在程序中加上數(shù)據(jù)庫(kù)的備份與恢復(fù)功能,所以需要使用到SQLDMO。

但在系統(tǒng)中沒(méi)有找到SQLDMO.dll,然后谷歌之,發(fā)現(xiàn)msdn上這樣說(shuō):

后續(xù)版本的 Microsoft SQL Server 將刪除該功能。

于是繼續(xù)谷歌,發(fā)現(xiàn)需要安裝Microsoft SQL Server 2005 向后兼容組件

這里下載:

Microsoft SQL Server 2005 向后兼容組件

SQL Server 向后兼容包中包含最新版本的 Data Transformation Services 2000 運(yùn)行庫(kù) (DTS)、SQL 分布式管理對(duì)象 (SQL-DMO)、決策支持對(duì)象 (DSO) 和 SQL 虛擬設(shè)備接口 (SQLVDI)。為了與 SQL Server 2005 和 SQL Server 2008 都兼容,這些版本已進(jìn)行了更新,并且包含 SQL Server 2000 SP4 和 SQL Server 2005 SP2 提供的所有修補(bǔ)程序。

用戶:客戶、合作伙伴、開(kāi)發(fā)人員

X86 包 (SQLServer2005_BC.msi) – 11273 KB
X64 包 (SQLServer2005_BC.msi) – 18569 KB

安裝完成后在c#項(xiàng)目引用中加上SQLDMO.dll即可

SQLDMO.dll在$Program Files$Microsoft SQL Server80ToolsBinn這個(gè)目錄里。

在恢復(fù)數(shù)據(jù)庫(kù)時(shí)需要注意的是,先將左右鏈接到數(shù)據(jù)庫(kù)的進(jìn)程kill掉,才能恢復(fù)。



SQLDMO.QueryResults qr = oSQLServer.EnumProcesses(-1);
int iColPIDNum = -1;
int iColDbName = -1;
//殺死其它的連接進(jìn)程
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分布式管理對(duì)象)封裝 Microsoft SQL Server 2000 數(shù)據(jù)庫(kù)中的對(duì)象。SQL-DMO 允許用支持自動(dòng)化或 COM 的語(yǔ)言編寫(xiě)應(yīng)用程序,以管理 SQL Server 安裝的所有部分。SQL-DMO 是 SQL Server 2000 中的 SQL Server 企業(yè)管理器所使用的應(yīng)用程序接口 (API);因此使用 SQL-DMO 的應(yīng)用程序可以執(zhí)行 SQL Server 企業(yè)管理器執(zhí)行的所有功能。

SQL-DMO 用于必須包含 SQL Server 管理的任何自動(dòng)化或 COM 應(yīng)用程序,例如: 
1.封裝 SQL Server 作為自己的數(shù)據(jù)存儲(chǔ)并想盡量減少用戶的 SQL Server 管理任務(wù)的應(yīng)用程序。
2.在程序本身并入了專(zhuān)門(mén)的管理邏輯的應(yīng)用程序。
3.想在自己的用戶界面中集成 SQL Server 管理任務(wù)的應(yīng)用程序。

SQLDMO對(duì)象來(lái)自SQLDMO.dll,SQLDMO.dll是隨SQL Server2000一起發(fā)布的。SQLDMO.dll自身是一個(gè)COM對(duì)象,因此,在你的.NET項(xiàng)目里必須先引用它。

private void Button3_Click(object sender, System.EventArgs e)
{
    //引用SQLDMO.dll,SQLDMO由Microsoft SQL Server自帶的SQLDMO.dll提供,SQLDMO.dll是一個(gè)COM對(duì)象
    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="數(shù)據(jù)庫(kù)備份";
    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服務(wù)器所有數(shù)據(jù)庫(kù)的列表
        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服務(wù)器的列表
        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;
        }


該文章在 2018/1/31 0:06:02 編輯過(guò)
關(guān)鍵字查詢(xún)
相關(guān)文章
正在查詢(xún)...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專(zhuān)業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國(guó)內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場(chǎng)、車(chē)隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場(chǎng)作業(yè)而開(kāi)發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類(lèi)企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉(cāng)儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷(xiāo)售管理,采購(gòu)管理,倉(cāng)儲(chǔ)管理,倉(cāng)庫(kù)管理,保質(zhì)期管理,貨位管理,庫(kù)位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved