Sub*_*niC 6 c# mysql setup-deployment installscript-msi
我有一个使用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
Run Code Online (Sandbox Code Playgroud)
配置:
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
Run Code Online (Sandbox Code Playgroud)
但是现在我不知道如何说Visual Studio在安装我的应用程序之前或之后做它.我一直在谷歌,但我找不到任何有用的帮助.
我希望你能指导我:)
编辑:我一直在使用自定义操作解决方案,我发现这篇文章使用自定义安装程序类来执行自定义操作.它看起来很好,但我得到一个问题,因为当我的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();
Run Code Online (Sandbox Code Playgroud)
您使用的是 Visual Studio 安装程序吗?如果是这样,您必须在安装程序上单击鼠标右键(在解决方案资源管理器中),然后转到“查看”并单击上下文菜单上的“自定义操作” 。
带有自定义操作的新树应出现在屏幕中央。然后,您可以右键单击任何文件夹(取决于您想要添加操作的时间)并选择添加自定义操作...
希望这对您有帮助...
| 归档时间: |
|
| 查看次数: |
1870 次 |
| 最近记录: |