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

简介:

在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_r(Assembly. GetExecutingAssembly_r().Location)+"yourname.mdf";  
  14. SqlParameter password=Cmd.Parameters.Add("@filename2",SqlDbType.NVarChar,50);  
  15. password.value =Path. GetDirectoryName_r(Assembly. GetExecutingAssembly_r().Location)+"yourname.ldf";  
  16. Connection.Open();  
  17. Cmd.ExecuteNonQuery();  
  18. Connection.Close();  

 

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

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




本文转自黄聪博客园博客,原文链接:http://www.cnblogs.com/huangcong/archive/2010/03/26/1697064.html,如需转载请自行联系原作者


相关文章
|
4月前
|
缓存 C# Windows
C#程序如何编译成Native代码
【10月更文挑战第15天】在C#中,可以通过.NET Native和第三方工具(如Ngen.exe)将程序编译成Native代码,以提升性能和启动速度。.NET Native适用于UWP应用,而Ngen.exe则通过预编译托管程序集为本地机器代码来加速启动。不过,这些方法也可能增加编译时间和部署复杂度。
276 2
|
2月前
|
算法 Java 测试技术
Benchmark.NET:让 C# 测试程序性能变得既酷又简单
Benchmark.NET是一款专为 .NET 平台设计的性能基准测试框架,它可以帮助你测量代码的执行时间、内存使用情况等性能指标。它就像是你代码的 "健身教练",帮助你找到瓶颈,优化性能,让你的应用跑得更快、更稳!希望这个小教程能让你在追求高性能的路上越走越远,享受编程带来的无限乐趣!
155 13
|
4月前
|
设计模式 程序员 C#
C# 使用 WinForm MDI 模式管理多个子窗体程序的详细步骤
WinForm MDI 模式就像是有超能力一般,让多个子窗体井然有序地排列在一个主窗体之下,既美观又实用。不过,也要小心管理好子窗体们的生命周期哦,否则一不小心就会出现一些意想不到的小bug
370 0
|
5月前
|
C# 容器
C#中的命名空间与程序集管理
在C#编程中,`命名空间`和`程序集`是组织代码的关键概念,有助于提高代码的可维护性和复用性。本文从基础入手,详细解释了命名空间的逻辑组织方式及其基本语法,展示了如何使用`using`指令访问其他命名空间中的类型,并提供了常见问题的解决方案。接着介绍了程序集这一.NET框架的基本单位,包括其创建、引用及高级特性如强名称和延迟加载等。通过具体示例,展示了如何创建和使用自定义程序集,并提出了针对版本不匹配和性能问题的有效策略。理解并善用这些概念,能显著提升开发效率和代码质量。
218 4
|
4月前
|
XML 存储 安全
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
216 0
|
4月前
|
安全 API C#
C# 如何让程序后台进程不被Windows任务管理器强制结束
C# 如何让程序后台进程不被Windows任务管理器强制结束
112 0
|
4月前
|
API C#
C#实现Winform程序右下角弹窗消息提示
C#实现Winform程序右下角弹窗消息提示
226 0
|
5月前
|
Linux C# 开发者
Uno Platform 驱动的跨平台应用开发:从零开始的全方位资源指南与定制化学习路径规划,助您轻松上手并精通 C# 与 XAML 编程技巧,打造高效多端一致用户体验的移动与桌面应用程序
【9月更文挑战第8天】Uno Platform 的社区资源与学习路径推荐旨在为初学者和开发者提供全面指南,涵盖官方文档、GitHub 仓库及社区支持,助您掌握使用 C# 和 XAML 创建跨平台原生 UI 的技能。从官网入门教程到进阶技巧,再到活跃社区如 Discord,本指南带领您逐步深入了解 Uno Platform,并提供实用示例代码,帮助您在 Windows、iOS、Android、macOS、Linux 和 WebAssembly 等平台上高效开发。建议先熟悉 C# 和 XAML 基础,然后实践官方教程,研究 GitHub 示例项目,并积极参与社区讨论,不断提升技能。
161 2
|
6月前
|
Android开发 iOS开发 C#
Xamarin.Forms:从零开始的快速入门指南——打造你的首个跨平台移动应用,轻松学会用C#和XAML构建iOS与Android通用界面的每一个步骤
【8月更文挑战第31天】Xamarin.Forms 是一个强大的框架,让开发者通过单一共享代码库构建跨平台移动应用,支持 iOS、Android 和 Windows。使用 C# 和 XAML,它简化了多平台开发流程并保持一致的用户体验。本指南通过创建一个简单的 “HelloXamarin” 应用演示了 Xamarin.Forms 的基本功能和工作原理。
150 0