VS2008中的安装部署

这两天项目要完成安装部署,用户还要求傻瓜式安装,直接附加数据库。从网上找了些VS2008制作安装部署的方法和附加数据库的方法,自己也从中遇到了些问题,在这和大家分享下。

遇到的问题:

1、应用程序中的文件夹如果希望使用condition来控制有无,只能将文件夹中的所有文件以此condition来设置,只设置文件夹的condition没有作用。

2、需要获取安装文件路径来控制程序安装时,最好建一个程序集,重写install类,在自定义操作中添加主输出来控制安装。需要设置CustomActionData属性,格式为:/installType=[INSTALLSTYLE] /targ="[TARGETDIR]\",详细信息和要求可以去MSDN中查阅。

3、怎么来控制安装部署自带的Dialog的下一步按钮是否有效还没有找到方法,自己写了个窗体来控制数据库的安装,使用Insall类来调用执行,单独使用Winform程序集输出不能获得到程序安装路径。

从网上找到的附加数据库的方法,分享如下:

        /// <summary>
        /// 执行附加数据库
      /// </summary>
        private void ExcuteAddDB() 
        {
               string targetPath= Context.Parameters["targ"];
               string server = ".";//服务器名称
            string uid = "sa";//SQlServer用户名
            string pwd = “sa”;//密码
            string path = targetPath;//安装目录
            string strSql = "server=" + server + ";uid=" + uid + ";pwd=" + pwd + ";database=master";//连接数据库字符串
            string DataName = "db";//数据库名
            string strMdf = path + @"db_Data.mdf";//MDF文件路径,这里需注意文件名要与刚添加的数据库文件名一样!
            string strLdf = path + @"db_Log.ldf";//LDF文件路径
            this.CreateDataBase(strSql, DataName, strMdf, strLdf, path);//开始创建数据库
        }

        /// <summary>
        /// 附加数据库方法
       /// </summary>
        /// <param name="strSql">连接数据库字符串,连接master系统数据库</param>
        /// <param name="DataName">数据库名字</param>
        /// <param name="strMdf">数据库文件MDF的路径</param>
        /// <param name="strLdf">数据库文件LDF的路径</param>
        /// <param name="path">安装目录</param>
        private void CreateDataBase(string strSql, string DataName, string strMdf, string strLdf, string path)
        {
            SqlConnection myConn = new SqlConnection(strSql);
            String str = null;
            try
            {
                str = " EXEC sp_attach_db @dbname='" + DataName + "',@filename1='" + strMdf + "',@filename2='" + strLdf + "'";
                SqlCommand myCommand = new SqlCommand(str, myConn);
                myConn.Open();
                myCommand.ExecuteNonQuery();
                MessageBox.Show("数据库附加成功!", "XXX", MessageBoxButtons.OK, MessageBoxIcon.Information);//需Using System.Windows.Forms
            }
            catch (Exception e)
            {
                MessageBox.Show("数据库附加失败!" + e.Message + "\n\n" + "需要手动附加数据数据库。数据库文件位置:" + "\n\n" + path , "XXX", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
            finally
            {
                myConn.Close();
            }
        }
posted on 2011-07-07 22:15  428 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/428Home/archive/2011/07/07/2100512.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值