2013-03-23 13 views
17

Ho il seguente nel mio file app.config. Sto usando Slow Cheetah e voglio solo sostituire sostituire configuration/entityFramework/defaultConnectionFactory/parameters/parameter in modo che punti ad un server diff. cioè sorgente del valore-dati = alcuni server ....Qual è il giusto xdt: parametro Locator per trasformare questo nodo?

<?xml version="1.0" encoding="utf-8"?> 
<configuration> 
    <configSections> 
    <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=4.4.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" /> 
    </configSections> 
    <appSettings> 
    </appSettings> 
    <startup> 
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.0" /> 
    </startup> 
    <entityFramework> 
    <defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework"> 
     <parameters> 
     <parameter value="data source=.;Integrated Security=SSPI;Initial Catalog=SomeDb;MultipleActiveResultSets=true" /> 
     </parameters> 
    </defaultConnectionFactory> 
    </entityFramework> 
    <system.web> 
    <membership defaultProvider="ClientAuthenticationMembershipProvider"> 
     <providers> 
     <add name="ClientAuthenticationMembershipProvider" type="System.Web.ClientServices.Providers.ClientFormsAuthenticationMembershipProvider, System.Web.Extensions, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" serviceUri="" /> 
     </providers> 
    </membership> 
    <roleManager defaultProvider="ClientRoleProvider" enabled="true"> 
     <providers> 
     <add name="ClientRoleProvider" type="System.Web.ClientServices.Providers.ClientRoleProvider, System.Web.Extensions, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" serviceUri="" cacheTimeout="86400" /> 
     </providers> 
    </roleManager> 
    </system.web> 
</configuration> 

ho cercato di quanto segue nella app.config.release ma senza alcun risultato.

<entityFramework> 
    <defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework"> 
     <parameters> 
     <parameter value="data source=dbserver;Integrated Security=SSPI;Initial Catalog=someDb;MultipleActiveResultSets=true" 
        xdt:Transform="Replace" 
        xdt:Locator="XPath(configuration/entityFramework/defaultConnectionFactory/parameters/parameter)" /> 
     </parameters> 
    </defaultConnectionFactory> 
    </entityFramework> 

anche provato xdt:Locator="Match(parameter)" e xdt:Locator="XPath(parameter)

e molti altri, ma non può farlo funzionare.

risposta

28

Ok. Mi sento un po 'sciocco, ma la soluzione è che non ho bisogno di specificare un xdt: localizzatore.

Se lascio semplicemente App.Release.Config in questo modo sostituirà la voce corrispondente.

<parameter value="data source=dbserver;Integrated Security=SSPI;Initial Catalog=someDb;MultipleActiveResultSets=true" 
       xdt:Transform="Replace"/> 
    </parameters> 
+9

Non sentirsi stupidi, la documentazione non è affatto chiara a riguardo! Grazie per aver pubblicato i tuoi risultati. –

+0

Ho avuto lo stesso problema con . Quello non ha un nome da usare per la corrispondenza, quindi ho appena usato il tuo metodo di sostituzione. –

+0

@TobyJ - La documentazione potrebbe non essere chiara ma quando ci si pensa, il localizzatore è qualcosa che aiuta a regolare la corrispondenza della posizione predefinita. Se non dai nulla, verrà utilizzata la gerarchia degli elementi. (se così non fosse, dovresti dare xdt: Locator ad ogni elemento antenato nella tua trasformazione lungo la catena) – arviman