VS2008中的安装部署
2011-07-07 22:15
465 查看
这两天项目要完成安装部署,用户还要求傻瓜式安装,直接附加数据库。从网上找了些VS2008制作安装部署的方法和附加数据库的方法,自己也从中遇到了些问题,在这和大家分享下。
遇到的问题:
1、应用程序中的文件夹如果希望使用condition来控制有无,只能将文件夹中的所有文件以此condition来设置,只设置文件夹的condition没有作用。
2、需要获取安装文件路径来控制程序安装时,最好建一个程序集,重写install类,在自定义操作中添加主输出来控制安装。需要设置CustomActionData属性,格式为:/installType=[INSTALLSTYLE] /targ="[TARGETDIR]\",详细信息和要求可以去MSDN中查阅。
3、怎么来控制安装部署自带的Dialog的下一步按钮是否有效还没有找到方法,自己写了个窗体来控制数据库的安装,使用Insall类来调用执行,单独使用Winform程序集输出不能获得到程序安装路径。
从网上找到的附加数据库的方法,分享如下:
遇到的问题:
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(); } }
相关文章推荐
- .net打包/C#WinFrom程序打包/图解.net打包/.net安装部署图解/VS2008项目的安装与部署图解
- C#WinFrom程序打包/图解VS2008项目的安装与部署图解
- .net打包/C#WinFrom程序打包/图解.net打包/.net安装部署图解/VS2008项目的安装与部署图解
- 关于VS2008安装部署的学习
- vs2008制作安装部署时如何包含.Net FrameWork 3.5 SP1
- 【转】vs2008安装部署工程制作教程
- vs2008安装部署工程制作教程
- vs2008 用文件部署生成的exe安装包
- .net打包/C#WinFrom程序打包/图解.net打包/.net安装部署图解/VS2008项目的安装与部署图解
- vs2008安装部署工程制作教程
- 简单的 vs2008 web安装部署打包心得
- C#WinFrom程序打包/图解VS2008项目的安装与部署图解
- .net打包/C#WinFrom程序打包/图解.net打包/.net安装部署图解/VS2008项目的安装与部署图解
- vs2008安装部署错误
- vs2008安装部署软件过程
- VS2008-其他引导程序包(安装部署项目的系统必备)
- vs2008安装部署工程制作教程
- VS2008 制作.net framework 2.0程序 安装部署的问题
- VS2008安装与部署
- C#WinFrom程序打包/图解VS2008项目的安装与部署图解