标签:string C# 数据库 install 引用 msi Installer result
首先,Msi是个数据库,也是第一次知道,用Orca数据库编辑工具能查看这个数据库中的各个表和字段;
知道了这些之后,就是如何在代码里实现了:
1、引用Microsoft Windows Installer Object Library这个Com组件,用它来操作这个数据库;可能会遇到引用失败,提示未能引用这个类,我就是一直引用不上,后来鼠标放到这个引用上,发现引用的是个本地的dll文件(C:\Windows\System32\msi.dll),直接把该文件拷贝到项目下,能正常引用,气不气;
2、然后就是代码,像这样:
//获取msi的版本号
private string GetMsiVersion(string installerPath) { Type t = Type.GetTypeFromProgID("WindowsInstaller.Installer"); Installer inst = (Installer)Activator.CreateInstance(t); Database d = inst.OpenDatabase( installerPath, MsiOpenDatabaseMode.msiOpenDatabaseModeReadOnly); View v = d.OpenView( "SELECT * FROM Property WHERE Property = 'ProductVersion'"); v.Execute(null); Record r = v.Fetch(); string result = r.get_StringData(2); return result; }
其他获取或修改,可以根据Orca工具,查看的表和字段,去自行修改sql语句就行了
标签:string,C#,数据库,install,引用,msi,Installer,result 来源: https://www.cnblogs.com/dachuang/p/15923953.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。