C#打包并附加数据库

开发平台:VisualStudio2010中文版

1. 打开要打包的项目,在“解决方案资源管理器”中右键添加新建项目

image_thumb[15]

2. 点击“项目类型”—“其他项目类型”—“安装和部署—Visual Studio Installer”,点击“安装项目”,明明之后点击“确定”

image_thumb[17]

3. 在在“文件系统”中点击“应用程序文件夹”,右键“添加—项目输出”会弹出一个对话框,点击确定

image_thumb[18]

image_thumb[19]

4. 再右击鼠标,“添加”--->点击“文件”,选择项目文件夹中的“bin”文件夹下的“Debug”文件夹中的exe文件

5. .单击“文件系统”中的“用户的"程序"菜单”,在右边空白处右击鼠标,点击“创建新的快捷方式”,把应用程序文件夹中的exe文件选上,点击确定。

image_thumb[4]

6. 单击“文件系统”中的“用户桌面”,操作如上一步骤。

7. 点击菜单栏中"生成"中的“生成Setup1(包名)”,等页面左下角显示"生成成功"即可

8. 在解决方案资源管理器中,新建一个类库项目InstallDB,,新建一个安装程序类[InstallDB.cs],等下将在这个类中编写附加数据库代码。

image_thumb[21]

image_thumb[22]

9. 在刚新建的安装项目上右键,【视图】->【用户界面】:

image_thumb[23]

10.在用户界面中,右键【启动】-【添加对话框】-选择【文本框(A)】-确定。

11.然后右键这个文本框(A),将其上移欢迎使用下面:

image_thumb[25]

12.右键选择属性

image_thumb[26]

Label 提示标签 Property 属性名 Value 默认值 Visible是否显示

13.在刚新建的安装项目上右键,【视图】->【自定义操作】:

14.右键【自定义操作界面】的【安装】节点,【添加自定义操作】,弹出的对话框

15.在查找范围里选择应用程序文件夹再点击右侧的【添加输出(O)…】,选择刚新建的安装程序类项目,默认还是主输出,确定。

image_thumb[28]

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.在安装项目的“文件系统”视图中,选择“应用程序文件夹”。右键菜单上, “添加”,然后选择“文件”,把刚才复制出来的两个数据库文件添加到安装项目中。

image_thumb[11]

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

image_thumb[29]

3.在快捷方式的属性窗口中Arguments属性设置为 /x {ProductCode}

image_thumb[30]

卸载方式只有快捷方式起作用

转载于:https://www.cnblogs.com/Mageric/archive/2012/08/08/2627681.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值