gpt4 book ai didi

c# - Wix 安装程序 - 更新多个连接字符串

转载 作者:太空宇宙 更新时间:2023-11-03 15:51:09 24 4
gpt4 key购买 nike

我对 Wix 有一些经验。最初我有一个带有一个连接字符串(下面的第一个)的配置文件,安装程序运行良好。现在我添加了另一个连接字符串,但我遇到了问题。 XML:

<util:XmlFile Id="leID2" File="[INSTALLFOLDER]Queue.exe.config" Sequence="3" Action="setValue" ElementPath="/configuration/connectionStrings/add[@name='String1']/@connectionString" Value="metadata=res://*/EntityModels.String1.csdl|res://*/EntityModels.String1.ssdl|res://*/EntityModels.String1.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=[DBSERVER];initial catalog=[DBNAME];User=User;Password=password;MultipleActiveResultSets=True;App=EntityFramework&quot;" Permanent="yes" />

<util:XmlFile Id="leID3" File="[INSTALLFOLDER]Queue.exe.config" Sequence="4" Action="setValue" ElementPath="/configuration/connectionStrings/add[@name='String2']/@connectionString" Value="metadata=res://*/EntityModels.String2.csdl|res://*/EntityModels.String2.ssdl|res://*/EntityModels.String2.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=[DBSERVER];initial catalog=[SECONDDBNAME];User=User;Password=password;MultipleActiveResultSets=True;App=EntityFramework&quot;" Permanent="yes" />

DBSERVER、DBNAME、SECONDDBNAME 都是从自定义用户输入窗口设置的属性。当我安装时,这是配置文件中的结果:

<add name="String1" connectionString="metadata=res://*/EntityModels.String1.csdl|res://*/EntityModels.String1.ssdl|res://*/EntityModels.String1.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=**mydbserver**;initial catalog=**seconddbname**;User=User;Password=password;MultipleActiveResultSets=True;App=EntityFramework&quot;" providerName="System.Data.EntityClient"/>

<add name="String2" connectionString="metadata=res://*/EntityModels.String2.csdl|res://*/EntityModels.String2.ssdl|res://*/EntityModels.String2.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=[default from project];initial catalog=[default from project];User=User;Password=password;MultipleActiveResultSets=True;App=EntityFramework&quot;" providerName="System.Data.EntityClient"/>

因此,第一个连接字符串正确地采用了 DBSERVER 名称,但它采用了输入的第二个数据库名称。第二个连接字符串与我在 visual studio 项目中的连接字符串保持完全不变。它没有被修改。

有什么想法吗?

最佳答案

由于您使用的是 XPATH,因此您需要在 util:XmlFile 节点中设置此属性:

SelectionLanguage="XPath" 

来源:

http://wixtoolset.org/documentation/manual/v3/xsd/util/xmlfile.html

编辑:

试试这个:

<util:XmlFile Id="leID2" File="[INSTALLFOLDER]Queue.exe.config" Sequence="3" Action="setValue" ElementPath="/configuration/connectionStrings/add[\[]@name='String1'[\]]/@connectionString" Value="metadata=res://*/EntityModels.String1.csdl|res://*/EntityModels.String1.ssdl|res://*/EntityModels.String1.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=[DBSERVER];initial catalog=[DBNAME];User=User;Password=password;MultipleActiveResultSets=True;App=EntityFramework&quot;" Permanent="yes" />

<util:XmlFile Id="leID3" File="[INSTALLFOLDER]Queue.exe.config" Sequence="4" Action="setValue" ElementPath="/configuration/connectionStrings/add[\[]@name='String2'[\]]/@connectionString" Value="metadata=res://*/EntityModels.String2.csdl|res://*/EntityModels.String2.ssdl|res://*/EntityModels.String2.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=[DBSERVER];initial catalog=[SECONDDBNAME];User=User;Password=password;MultipleActiveResultSets=True;App=EntityFramework&quot;" Permanent="yes" />

关于c# - Wix 安装程序 - 更新多个连接字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25745191/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com