C#安装程序中打包MSDE的八个步骤

开发 后端
这里将介绍C#安装程序中打包MSDE的八个步骤,在Visual Studio 2003的工程中添加Microsoft SQL Server 2000 Desktop Engine (MSDE)的自动安装合并模块MSM。

在Visual Studio 2003的工程中添加Microsoft SQL Server 2000 Desktop Engine (MSDE)的自动安装合并模块MSM:

1.下载MSDE2000的sp3a安装包。

2.解压到本地硬盘,其中的MSM文件夹中的东东就是MSDE2000合并模块。

3.在你的工程中添加一个安装工程假设为MySetup,按照正常的步骤添加工程输出(Project Output),选择输出文件(primary output)和内容文件(content files)两项。

4.添加合并模块(Merge Moudle),选择浏览,指定到你的MSDE的MSM文件夹,选择MSM(不包括msm1033和msm2052)下的所有的文件(REPL.MSM、REPL_RES.MSM、 DMO_RES.MSM和DMO.MSM可以不选),打开。

5.设置安装工程的属性(Properties)中的SearchPath,指定为你的MSM所在路径(MSM和MSM1033和MSM2052)。

6.设置好安装程序的其他属性,这时就可以对你的安装工程进行编译了。

7.我们需要修改打好的安装包,使它可以在安装完程序后自动安装MSDE的一个实例(假设实例名为:MyServer)。我们需要用到MS的一个工具ORCA

8.用ORCA打开安装包文件MySetup.msi

InstallExecuteSequence表

GetSqlStates.XXXXXX             103->421

InstallInitialize                          1800->1799

RemoveExistingProducts     1825->1800

InstallUISequence表

GetSqlStates.XXXXXX        103->421

Property表添加

SqlInstanceName:          MSDEDH实例服务名

SqlSecurityMode:          SQL 用SQL模式登录

SqlSaPwd:                 sa的密码

DISABLENETWORKPROTOCOLS=0:网络访问的话也要加这项

重写C#安装程序Installer

下面方法适用于C#安装程序,没有添加SqlInstanceName:这个属性,用机器名访问msde

  1. public override void Commit(IDictionary savedState)  
  2. {  
  3. base.Commit (savedState);  
  4. //启动windows服务  
  5. new System.ServiceProcess.ServiceController("MSSQLSERVER").Start();  
  6. //附加数据库  
  7. SqlConnection Connection = new SqlConnection("password=**;user id=sa;data source="+SystemInformation.ComputerName);  
  8. SqlCommand Cmd = new SqlCommand("sp_attach_db",Connection);  
  9. Cmd.CommandType = CommandType.StoredProcedure;  
  10. SqlParameter loginname=Cmd.Parameters.Add("@dbname",SqlDbType.NVarChar,20);  
  11. loginname.value ="yourname";  
  12. SqlParameter nickname=Cmd.Parameters.Add("@filename1",SqlDbType.NVarChar,50);  
  13. nickname.value =Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location)+"yourname.mdf";  
  14. SqlParameter password=Cmd.Parameters.Add("@filename2",SqlDbType.NVarChar,50);  
  15. password.value =Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location)+"yourname.ldf";  
  16. Connection.Open();  
  17. Cmd.ExecuteNonQuery();  
  18. Connection.Close();  

用附加数据库,我认为是***的解决办法。

在没有SQL环境的机器上运行你的C#安装程序,会自动安装MSDE,并附加你的数据库,重起机器后,自动启动Sql Server的实例。

【编辑推荐】

  1. C#枚举类型实例解析
  2. C#枚举类型开发学习心得
  3. C#枚举类型学习之基础讲解
  4. C#枚举类型语法浅析
  5. C#枚举类型基础学习浅析
责任编辑:彭凡 来源: etiersoft.com
相关推荐

2017-04-20 12:51:28

2023-02-27 09:08:10

IT文化步骤

2012-11-20 10:01:40

程序员

2013-11-01 11:06:33

数据

2018-06-12 10:37:12

云计算迁移步骤

2023-02-15 14:09:57

云托管云退出策略

2023-12-05 07:17:27

人工智能企业

2011-10-08 10:23:13

云计算云服务

2010-04-25 23:21:57

2022-01-11 14:47:48

人工智能工程挖掘自动化流程发现

2022-11-04 15:37:04

产品策略开发竞争

2023-01-03 11:47:47

2009-08-13 17:15:44

C#屏幕保护程序

2023-12-31 19:11:26

2023-12-10 14:39:25

删除图片开源图片背景移除

2022-12-01 16:53:27

NPM技巧

2021-08-20 10:05:32

勒索软件恶意软件安全

2010-01-05 15:16:56

交换机配置dhcp

2023-02-25 10:00:19

开源项目小程序

2010-09-02 16:14:20

CSS布局
点赞
收藏

51CTO技术栈公众号