新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论.NET,C#,ASP,VB技术
    [返回] 中文XML论坛 - 专业的XML技术讨论区计算机技术与应用『 Dot NET,C#,ASP,VB 』 → C#备份和还原SQL数据库 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 8386 个阅读者浏览上一篇主题  刷新本主题   平板显示贴子 浏览下一篇主题
     * 贴子主题: C#备份和还原SQL数据库 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     卷积内核 帅哥哟,离线,有人找我吗?
      
      
      威望:8
      头衔:总统
      等级:博士二年级(版主)
      文章:3942
      积分:27590
      门派:XML.ORG.CN
      注册:2004/7/21

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给卷积内核发送一个短消息 把卷积内核加入好友 查看卷积内核的个人资料 搜索卷积内核在『 Dot NET,C#,ASP,VB 』的所有贴子 访问卷积内核的主页 引用回复这个贴子 回复这个贴子 查看卷积内核的博客楼主
    发贴心情 C#备份和还原SQL数据库

    using System;
    using System.Data;
    using System.Data.SqlClient;

    namespace bachupsqlserver
    {
        /// <summary>
        /// 备份和还原sql server 2000数据库,在asp.net中文正式版和sql server 2000系统上通过
        /// </summary>
        public class BackupData
        {
            private SqlConnection conn;
            public BackupData()
            {
                //
                // TODO: 在此处添加构造函数逻辑
                //

                //注意默认数据库不要和恢复的数据库同名
                string sql="data source=localhost;initial catalog=master;password=;persist security info=True;user id=sa;

    workstation id=TOPS03496;packet size=4096";

                init(sql);
            }

            /// <summary>
            /// 备份数据库
            /// </summary>
            /// <param name="databasename">要备份的数据源名称</param>
            /// <param name="backuptodatabase">备份到的数据库文件名称及路径</param>
            /// <returns></returns>
            public bool BackUpDataBase(string databasename,string backuptodatabase)
            {
                string procname;
                string name=databasename+DateTime.Now.Year.ToString()+DateTime.Now.Month.ToString()+DateTime.Now.Date.Day.ToString()+DateTime.Now.Minute.ToString();
                string sql;

                conn.Open();        //打开数据库连接

                //删除逻辑备份设备,但不会删掉备份的数据库文件
                procname="sp_dropdevice";
                SqlCommand sqlcmd1=new SqlCommand(procname,conn);
                sqlcmd1.CommandType =CommandType.StoredProcedure;

                SqlParameter sqlpar=new SqlParameter();
                sqlpar=sqlcmd1.Parameters.Add("@logicalname",SqlDbType.VarChar,20);
                sqlpar.Direction =ParameterDirection.Input;
                sqlpar.Value =databasename;

                try        //如果逻辑设备不存在,略去错误
                {
                    sqlcmd1.ExecuteNonQuery();
                }
                catch
                {
                }

                //创建逻辑备份设备
                procname="sp_addumpdevice";
                SqlCommand sqlcmd2=new SqlCommand(procname,conn);
                sqlcmd2.CommandType =CommandType.StoredProcedure;

                sqlpar=sqlcmd2.Parameters.Add("@devtype",SqlDbType.VarChar,20);
                sqlpar.Direction =ParameterDirection.Input;
                sqlpar.Value ="disk";

                
                sqlpar=sqlcmd2.Parameters.Add("@logicalname",SqlDbType.VarChar,20);//逻辑设备名
                sqlpar.Direction =ParameterDirection.Input;
                sqlpar.Value =databasename;

                sqlpar=sqlcmd2.Parameters.Add("@physicalname",SqlDbType.NVarChar,260);//物理设备名
                sqlpar.Direction =ParameterDirection.Input;
                sqlpar.Value =backuptodatabase+name+".bak";

                
                try
                {
                    int i=sqlcmd2.ExecuteNonQuery();
                }
                catch(Exception err)
                {
                    string str=err.Message;
                }

                //备份数据库到指定的数据库文件(完全备份)
                sql="BACKUP DATABASE "+databasename +" TO "+databasename +" WITH INIT";
                SqlCommand sqlcmd3=new SqlCommand(sql,conn);
                sqlcmd3.CommandType =CommandType.Text;
                try
                {
                    sqlcmd3.ExecuteNonQuery();
                }
                catch(Exception err)
                {
                    string str=err.Message ;
                    conn.Close();

                    return false;
                }

                conn.Close();//关闭数据库连接
                return true;

            }

            /// <summary>
            /// 还原指定的数据库文件
            /// </summary>
            /// <param name="databasename">要还原的数据库</param>
            /// <param name="databasefile">数据库备份文件及路径</param>
            /// <returns></returns>
            public bool RestoreDataBase(string databasename,string databasefile )
            {

                //还原指定的数据库文件
                string sql="RESTORE DATABASE "+databasename +" from DISK = '"+databasefile +"' ";
                SqlCommand sqlcmd=new SqlCommand(sql,conn);
                sqlcmd.CommandType =CommandType.Text;

                conn.Open();

                try
                {
                    sqlcmd.ExecuteNonQuery();
                }
                catch(Exception err)
                {
                    string str=err.Message ;
                    conn.Close();

                    return false;
                }

                conn.Close();//关闭数据库连接
                return true;
            }

            /// <summary>
            /// 初始化数据库的连接
            /// </summary>
            /// <param name="strconn"></param>
            private void init(string strconn)
            {
                conn=new SqlConnection(strconn);

            }
        }
    }


       收藏   分享  
    顶(0)
      




    ----------------------------------------------
    事业是国家的,荣誉是单位的,成绩是领导的,工资是老婆的,财产是孩子的,错误是自己的。

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2010/6/14 14:33:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 Dot NET,C#,ASP,VB 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/4/19 7:30:03

    本主题贴数1,分页: [1]

     *树形目录 (最近20个回帖) 顶端 
    主题:  C#备份和还原SQL数据库(4735字) - 卷积内核,2010年6月14日

    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    125.000ms