开发平台:VisualStudio2010中文版
1. 打开要打包的项目,在“解决方案资源管理器”中右键添加新建项目
2. 点击“项目类型”—“其他项目类型”—“安装和部署—Visual Studio Installer”,点击“安装项目”,明明之后点击“确定”
3. 在在“文件系统”中点击“应用程序文件夹”,右键“添加—项目输出”会弹出一个对话框,点击确定
4. 再右击鼠标,“添加”--->点击“文件”,选择项目文件夹中的“bin”文件夹下的“Debug”文件夹中的exe文件
5. .单击“文件系统”中的“用户的"程序"菜单”,在右边空白处右击鼠标,点击“创建新的快捷方式”,把应用程序文件夹中的exe文件选上,点击确定。
6. 单击“文件系统”中的“用户桌面”,操作如上一步骤。
7. 点击菜单栏中"生成"中的“生成Setup1(包名)”,等页面左下角显示"生成成功"即可
8. 在解决方案资源管理器中,新建一个类库项目InstallDB,,新建一个安装程序类[InstallDB.cs],等下将在这个类中编写附加数据库代码。
9. 在刚新建的安装项目上右键,【视图】->【用户界面】:
10.在用户界面中,右键【启动】-【添加对话框】-选择【文本框(A)】-确定。
11.然后右键这个文本框(A),将其上移到欢迎使用下面:
12.右键选择属性
Label 提示标签 Property 属性名 Value 默认值 Visible是否显示
13.在刚新建的安装项目上右键,【视图】->【自定义操作】:
14.右键【自定义操作界面】的【安装】节点,【添加自定义操作】,弹出的对话框
15.在查找范围里选择应用程序文件夹,再点击右侧的【添加输出(O)…】,选择刚新建的安装程序类项目,默认还是主输出,确定。
16.右键这个【主输出来自InstallDB(活动)】,进入属性界面,在【CustomActionData】属性里输入下面的内容:
/dbname=[DBNAME] /server=[SERVER] /user=[USER] /pwd=[PWD] /targetdir="[TARGETDIR]\"
说明:其中前四个方括号中的大写字母,为上面第12步图中输入的四个EditProPerty属性,需要对应好。最后一个targetdir的值的意思是安装后文件的目录路径。
特别提醒:前三个"/XXX=[XXX]"后面 ,都有一个空格的
17.将SQL Server数据库文件分离(在企业管理器中右击数据库->所有工作->分离数据库,分离得两上文件,一个是数据主文件Demo.mdf,一个是日志文件Demo_Log.LDF),复制到项目文件夹中
18.在安装项目的“文件系统”视图中,选择“应用程序文件夹”。右键菜单上, “添加”,然后选择“文件”,把刚才复制出来的两个数据库文件添加到安装项目中。
19.将安装文件LisenceFile.rtf添加到“setup1”项目
20.在用户界面编辑器中,选择许可协议,设置LisenceFile属性为LisenceFile.rtf文件
21.先生成类库项目: installDB,再生成安装项目
using System;
using System.Collections;
using System.Collections.Generic;
using System.ComponentModel;
using System.Configuration.Install;
using System.Linq;
using System.Windows.Forms;
using System.Data;
using System.Data.SqlClient;
/// <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("数据库安装成功!点击确定继续");//需Using System.Windows.Forms
}
catch(Exception e)
{
MessageBox.Show("数据库安装失败!" + e.Message+"\n\n"+"您可以手动附加数据");
System.Diagnostics.Process.Start(path);//打开安装目录
}
finally
{
myConn.Close();
}
}
public override void Install(System.Collections.IDictionary stateSaver)
{
string server = this.Context.Parameters["server"];//服务器名称
string uid = this.Context.Parameters["user"];//SQlServer用户名
string pwd = this.Context.Parameters["pwd"];//密码
string path = this.Context.Parameters["targetdir"];//安装目录
string strSql = "server=" + server + ";uid=" + uid + ";pwd=" + pwd + ";database=master";//连接数据库字符串
string DataName = "Demo";//数据库名
string strMdf = path + @"Demo.mdf";//MDF文件路径,这里需注意文件名要与刚添加的数据库文件名一样!
string strLdf = path + @"Demo_log.ldf";//LDF文件路径
base.Install(stateSaver);
this.CreateDataBase(strSql, DataName, strMdf, strLdf, path);//开始创建数据库
}
FAQ:
1. 数据库附加之后再次安装会失败,卸载之后也可能出现错误。重新登陆数据库管理将数据库分离
添加卸载:
1.在安装项目的文件系统视图中,应用程序文件夹右键添加-文件,添加一个msiexec.exe 该文件位于c:\windows\system32\msiexec.exe
为了让他更像个卸载程序,把他的名字改成"Uninstall.exe"
2.在开始菜单中创建一个快捷方式,
在安装项目的属性窗口中找到ProductCode
3.在快捷方式的属性窗口中Arguments属性设置为 /x {ProductCode}
卸载方式只有快捷方式起作用
本文介绍如何使用Visual Studio 2010进行项目打包,并详细阐述了在打包过程中如何实现数据库的附加操作,包括创建安装程序、自定义安装界面以及卸载程序的制作。
![image_thumb[15] image_thumb[15]](/https://i-blog.csdnimg.cn/blog_migrate/3edeb0ea43f464921c64eac58df47f5d.png)
![image_thumb[17] image_thumb[17]](/https://i-blog.csdnimg.cn/blog_migrate/847902699cf75f2eefb7219831f5a889.png)
![image_thumb[18] image_thumb[18]](/https://i-blog.csdnimg.cn/blog_migrate/e80c3e65200b3e2e69e2f79d2003fad9.png)
![image_thumb[19] image_thumb[19]](/https://i-blog.csdnimg.cn/blog_migrate/dbc876d89cb262b9777b725824f5ce5f.png)
![image_thumb[4] image_thumb[4]](/https://i-blog.csdnimg.cn/blog_migrate/700f5d1482b3772d2c8080a1b1ac300c.png)
![image_thumb[21] image_thumb[21]](/https://i-blog.csdnimg.cn/blog_migrate/4f2d1d826fdd3de566e351ce854e3e5e.png)
![image_thumb[22] image_thumb[22]](/https://i-blog.csdnimg.cn/blog_migrate/a9d33637a1371b0571974e69f662ae47.png)
![image_thumb[23] image_thumb[23]](/https://i-blog.csdnimg.cn/blog_migrate/78cdb90d453eed484a418e807e96ad61.png)
![image_thumb[25] image_thumb[25]](/https://i-blog.csdnimg.cn/blog_migrate/52faed6b25b382b0fad8198d093a0df0.png)
![image_thumb[26] image_thumb[26]](/https://i-blog.csdnimg.cn/blog_migrate/0a925bf44bd7b1a04c4bbca6b935b36c.png)
![image_thumb[28] image_thumb[28]](/https://i-blog.csdnimg.cn/blog_migrate/3371dd31bafccefd1d10fbf0288beec9.png)
![image_thumb[11] image_thumb[11]](/https://i-blog.csdnimg.cn/blog_migrate/e0d52e75735d1542e96ae78e2b190dbe.png)
![image_thumb[29] image_thumb[29]](/https://i-blog.csdnimg.cn/blog_migrate/fae178d0b7a5a40b2b8a27489b5d2b09.png)
![image_thumb[30] image_thumb[30]](/https://i-blog.csdnimg.cn/blog_migrate/f9761eda94d79267c5e6b184281f6cb0.png)

3682

被折叠的 条评论
为什么被折叠?



