• C#数据库备份及还原的实现代码


     // 1.在用户的配置时,我们需要列出当前局域网内所有的数据库服务器,并且要列出指定服务器的所有数据库,实现代码如下:
    
        //取得数据库服务器列表:
            public ArrayList GetServerList()
            {
                ArrayList alServers = new ArrayList();
                SQLDMO.Application sqlApp = new SQLDMO.ApplicationClass();
                try
                {
                    SQLDMO.NameList serverList = sqlApp.ListAvailableSQLServers();
                    for (int i = 1; i <= serverList.Count; i++)
                    {
                        alServers.Add(serverList.Item(i));
                    }
                }
                catch (Exception e)
                {
                    throw (new Exception("取数据库服务器列表出错:" + e.Message));
                }
                finally { sqlApp.Quit(); }
                return alServers;
            }     
            //取得指定数据库服务器的数据库列表   
            public ArrayList GetDbList(string strServerName, string strUserName, string strPwd)
            {
                ServerName = strServerName;
                UserName = strUserName;
                Password = strPwd;
    
                ArrayList alDbs = new ArrayList();
                SQLDMO.Application sqlApp = new SQLDMO.ApplicationClass();
                SQLDMO.SQLServer svr = new SQLDMO.SQLServerClass();
                try
                {
                    svr.Connect(ServerName, UserName, Password);
                    foreach (SQLDMO.Database db in svr.Databases)
                    {
                        if (db.Name != null)
                            alDbs.Add(db.Name);
                    }
                }
                catch (Exception e)
                {
                    throw (new Exception("连接数据库出错:" + e.Message));
                }
                finally
                {
                    svr.DisConnect();
                    sqlApp.Quit();
                }
                return alDbs;
            }
    //     //2.数据库的备份和实时进度显示代码: 
    
            public bool BackUPDB(string strDbName, string strFileName, ProgressBar pgbMain)
            {
                PBar = pgbMain; SQLDMO.SQLServer svr = new SQLDMO.SQLServerClass();
                try
                {
                    svr.Connect(ServerName, UserName, Password);
                    SQLDMO.Backup bak = new SQLDMO.BackupClass();
                    bak.Action = 0;
                    bak.Initialize = true;
                    SQLDMO.BackupSink_PercentCompleteEventHandler pceh = new SQLDMO.BackupSink_PercentCompleteEventHandler(Step);
                    bak.PercentComplete += pceh;
                    bak.Files = strFileName;
                    bak.Database = strDbName;
                    bak.SQLBackup(svr);
                    return true;
                }
                catch (Exception err) 
                { 
                    throw (new Exception("备份数据库失败" + err.Message));
                }
                finally 
                { 
                    svr.DisConnect(); 
                }
            }
            private void Step(string message, int percent)
            {
                PBar.Value = percent;
            }     
          //其中,这两个语句实现了进度的实时显示:
    
         //SQLDMO.BackupSink_PercentCompleteEventHandler pceh = new    
         //SQLDMO.BackupSink_PercentCompleteEventHandler(Step); 
         //bak.PercentComplete += pceh;
    
         //Step就是上面private void Step(string message,int percent) 的方法名称,它用来显示进度条的当前进度。
    
        //3.数据库的恢复和杀死进程的代码:
    
            public bool RestoreDB(string strDbName, string strFileName, ProgressBar pgbMain)
            {
                PBar = pgbMain;
                SQLDMO.SQLServer svr = new SQLDMO.SQLServerClass();
                try
                {
                    svr.Connect(ServerName, UserName, Password);
                    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() == "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() == strDbName.ToUpper()) svr.KillProcess(lPID);
                    }
                    SQLDMO.Restore res = new SQLDMO.RestoreClass();
                    res.Action = 0;
                    SQLDMO.RestoreSink_PercentCompleteEventHandler pceh = new SQLDMO.RestoreSink_PercentCompleteEventHandler(Step);
                    res.PercentComplete += pceh;
                    res.Files = strFileName;
                    res.Database = strDbName; res.ReplaceDatabase = true; res.SQLRestore(svr);
                    return true;
                }
                catch (Exception err)
                {
                    throw (new Exception("恢复数据库失败,请关闭所有和该数据库连接的程序!" + err.Message));
                }
                finally
                {
                    svr.DisConnect();
                }
            }    
             //其中这个语句取得了所有的进程列表:
    
             //    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() == "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() == strDbName.ToUpper()) 
                        svr.KillProcess(lPID) ; 
                 }  

    转载:作者不详
    连接:http://www.codesky.net/article/200908/128600.html

  • 相关阅读:
    jmeter Transaction Controller、Throughput Controller 控制器
    图书系统的简易代码
    模板简单梳理
    自制过滤器
    自制URL转换器
    URL简单梳理
    window下的Django入门
    十一、常用内建模块
    九、进程与线程
    八、错误、调试与测试
  • 原文地址:https://www.cnblogs.com/liubaolongcool/p/2568647.html
Copyright © 2020-2023  润新知