c# – 使用VisualStudio 2005应用程序部署MySQL服务器

我有一个使用MySQL作为数据存储引擎的Visual Studio 2005项目(C#),我想创建一个安装应用程序的MSI包,并在安装MysqL后静.我一直在调查它,但我找不到太多信息.

我已经静安装了MysqL软件包,并在CMD中配置了这两个语句

安装:

msiexec /qb /i "c:\MysqL.msi" /l* d:\log_MysqL_test.txt INSTALLDIR=d:\MysqL_test_mdps

配置:

D:\MysqL_test_mdps\bin\MysqLInstanceConfig.exe -i -q "-lD:\MysqL_config_log.txt" "-pD:\MysqL_test_mdps\bin" "-tD:\MysqL_test_mdps\my-template.ini" "-cD:\MysqL_test_mdps\my.ini" -v5.5.9 ServerType=DEVELOPMENT DatabaseType=MIXED ConnectionUsage=DSS Port=53306 ServiceName=MysqL_AGM RootPassword=root1234 SkipNetworking=no AddBinToPath=yes

但是现在我不知道如何说Visual Studio在安装我​​的应用程序之前或之后做它.我一直在谷歌,但我找不到任何有用的帮助.

我希望你能指导我:)

编辑:我一直在使用自定义操作解决方案,我发现这个article使用自定义安装程序类来执行自定义操作.它看起来很好,但我得到一个问题,因为当我的MSI包尝试启动第二个MSI安装程序(MysqL)时,我收到错误,代码为2869,显示“拒绝访问”.

我一直在寻找这个问题,看起来当第一个MSI尝试运行第二个MSI时,它没有应用正确的权限,安装失败……

你知道我能做什么吗?或者我如何启动第二个MSI安装程序?具有完全权限(或至少与第一个安装程序相同)

这是我用来创建Process对象的代码.

string arg1 = "/qb /i \"" + filepath + "\" /l* \"" + Path.Combine(installpath,logfile) + "\" INSTALLDIR=\"" + installpath + "\"";

Process p = new Process();
p.StartInfo.FileName = "msiexec.exe";
p.StartInfo.Arguments = arg1;
p.Start();
最佳答案
你不需要启动另一个msiexec.exe. Visual Studio还允许您将可执行文件用作自定义操作.所以自定义动作

见下文.图片来自这个link

在上面的链接中查看“将可执行文件调用自定义操作”部分.现在,如果这不起作用,则可以修改认的bootstrapper.

在此链接中查看0xA3的回复.
Running another program from c# setup project

它看起来并不复杂.

相关文章

优化MySQL数据库发布系统存储的方法有:1.mysql库主从读写分...
使用mysql的方法:在“我的电脑”→右键→“管理”→“服务”...
在mysql中查看root用户权限的方法:1.命令行启动mysql服务;...
MySQL主从复制是用来备份一个与主数据库一样环境的从数据库,...
运行mysql的方法1.启动mysql服务,在“我的电脑”→右键→“...
开启mysql的方法1.可以通过快捷键win+r,输入cmd,打开窗口,...