文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

C#安装程序中打包MSDE的详细步骤

2023-06-17 23:38

关注

这篇文章主要讲解了“C#安装程序中打包MSDE的详细步骤”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#安装程序中打包MSDE的详细步骤”吧!

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

下载MSDE2000的sp3a安装包。

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

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

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

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

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

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

用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

public override void Commit(IDictionary savedState)  {  base.Commit (savedState);  //启动windows服务  new System.ServiceProcess.ServiceController("MSSQLSERVER").Start();  //附加数据库  SqlConnection Connection = new SqlConnection("password=**;user id=sa;data source="+SystemInformation.ComputerName);  SqlCommand Cmd = new SqlCommand("sp_attach_db",Connection);  Cmd.CommandType = CommandType.StoredProcedure;  SqlParameter loginname=Cmd.Parameters.Add("@dbname",SqlDbType.NVarChar,20);  loginname.value ="yourname";  SqlParameter nickname=Cmd.Parameters.Add("@filename1",SqlDbType.NVarChar,50);  nickname.value =Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location)+"yourname.mdf";  SqlParameter password=Cmd.Parameters.Add("@filename2",SqlDbType.NVarChar,50);  password.value =Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location)+"yourname.ldf";  Connection.Open();  Cmd.ExecuteNonQuery();  Connection.Close();  }

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

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

感谢各位的阅读,以上就是“C#安装程序中打包MSDE的详细步骤”的内容了,经过本文的学习后,相信大家对C#安装程序中打包MSDE的详细步骤这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯