2013-03-23 12 views
17

Mam następujące w moim pliku app.config. Używam Slow Cheetah i po prostu chcę zastąpić zamianę configuration/entityFramework/defaultConnectionFactory/parameters/parameter tak, aby wskazywało serwer diff. czyli źródło wartości data = jakiś serwer ....Jaki jest właściwy parametr xdt: Locator do transformacji tego węzła?

<?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> 

Próbowałem następujących w app.config.release ale bezskutecznie.

<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> 

próbował również xdt:Locator="Match(parameter)" i xdt:Locator="XPath(parameter)

i wiele więcej, ale nie może zmusić go do pracy.

Odpowiedz

28

Ok. Czuję się trochę głupio, ale rozwiązaniem jest to, że nie muszę określać xdt: Locator.

Jeśli po prostu opuści App.Release.Config w ten sposób zastąpi pasujący wpis.

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

Nie czuj się głupio, dokumentacja nie jest wcale jasna! Dziękujemy za przesłanie wyników. –

+0

Miałem ten sam problem z . Ten nie ma nazwy, której można użyć do dopasowania, więc użyłem twojej metody zamiany. –

+0

@TobyJ - Dokumentacja może nie być jasna, ale gdy się nad tym zastanowisz, lokalizator pomoże Ci dostroić domyślną lokalizację. Jeśli nic nie podasz, użyjesz hierarchii elementów. (jeśli nie, musisz podać xdt: Locator na każdym elemencie przodka w transformacji wzdłuż łańcucha) – arviman

Powiązane problemy