RSS FeedFeed TwitterTwitter XINGXING
  
Meine Bücher

Verteilte Systeme und Services mit .NET 4.0: Konzepte und Lösungen mit WCF 4.0,
Hanser Fachbuchverlag

Weitere Infos

 

.NET 4 Update,
Microsoft Press

Weitere Infos

 
Weitere Bücher
Meine Artikel

Leichtgewichtige Kommunikation: REST-basierte Services mit dem neuen API aus der ASP.NET-Familie,
windows.developer

Weitere Infos

 

EAI und EDI in der Cloud ,
windows.developer

Weitere Infos

 

Verteilt und doch ein Ganzes: Verteilte Systeme mit AppFabric Applications,
dot.net magazin

Weitere Infos

 

Vorschau auf Neuerungen der kommenden WCF-Version,
dot.net magazin

Weitere Infos

 

Windows Azure Tutorial, Teil 3: Verbindung zwischen Cloud- und lokalen Applikationen,
iX - Magazin für professionelle Informationstechnik

Weitere Infos

 

MVC, die dritte: ASP.NET MVC 3 RC 2,
dot.net magazin

Weitere Infos

 

Leichtgewichtiges O/R-Mapping - Code Only mit Entitiy Framework CTP 5,
dot.net magazin

Weitere Infos

 

Weitere Artikel

Training & Beratung

Gemeinsam mit meinen Kollegen aus dem IT-Visions Netzwerk unterstützte ich durch zielgerichtete Inhouse-Schulungen und Beratung Unternehmen bei der Planung und Umsetzung von großer Software-Systeme.

Mehr lesen

In Kontakt treten

 
Konferenzen

BASTA! on Tour von 4/25/2012 bis 4/27/2012 in Düsseldorf

Meine Talks

Web-Site der Konferenz

 

BASTA! Spring 2012 von 2/27/2012 bis 3/2/2012 in Darmstadt

Meine Talks

Web-Site der Konferenz

 

ADC - Advanced Developers Conference von 10/26/2011 bis 10/27/2011 in Frankental (Deutschland)

Meine Talks

Web-Site der Konferenz

 

Scandev on tour von 10/18/2011 bis 10/18/2011 in Stockholm (Schweden)

Meine Talks

Web-Site der Konferenz

 

BASTA 2011 von 9/26/2011 bis 9/30/2011 in Mainz

Meine Talks

Web-Site der Konferenz

 

Jazoon - International Conference on the modern art of software von 6/21/2011 bis 6/23/2011 in Zürich

Meine Talks

Web-Site der Konferenz

 

Scandinavian Developer Conference 2011 von 4/4/2011 bis 4/5/2011 in Göteborg (Schweden)

Meine Talks

Web-Site der Konferenz

 

SOA-Days von 3/30/2011 bis 3/31/2011 in Bonn

Meine Talks

Web-Site der Konferenz

 
Weitere Konferenzen
von Manfred, 15. September 2010 20:38

Möchte man Tabellen nicht direkt mappen, kann auf die Möglichkeit, Views auf Klassen zu mappen und Inserts, Updates und Deletes über Stored Procedures stattfinden zu lassen, ausgewichen werden. Soll sich der SQL-Code zum Laden, Einfügen, Speichern und Löschen jedoch im EDM wiederfinden, können diese Stored Procedures und diese View auch direkt innerhalb des Storage-Models im EDM definiert werden. Da es somit sein kann, dass bestimmte im Storage-Model definierte Tabellen nicht mehr gemappt sind (weil sie ja über die View und die SPs gemappt sind) müssen diese entfernt werden.

Der Nachteil dieser Lösung: Man muss dies manuell – also direkt im XML-File – machen und beim nächsten „Update Model from Database“ gehen solche Änderungen verloren.

Nachfolgend ein paar Snippets, die dieses Szenario skizzieren.

Native Funktion im Storage Model:
<Function Name="Rtlwtz" IsComposable="false">
<CommandText>
  insert into Hotel2(Bezeichnung, Sterne, RegionId, BildPfad)
  values (@Bezeichnung, @Sterne, @RegionId, @BildPfad);
  select SCOPE_IDENTITY() as HotelId;
</CommandText>
<Parameter Name="Bezeichnung" Type="varchar" />
<Parameter Name="Sterne" Type="int" />
<Parameter Name="RegionId" Type="int" />
<Parameter Name="BildPfad" Type="varchar" />
</Function>

Die “View” im Storage Model als EntityType:
<EntitySet Name="CustomHotel" EntityType="HotelDbModel.Store.CustomHotel" store:Type="Views">
  <DefiningQuery>
    select
      HotelId,
      Bezeichnung + '!' as Bezeichnung,
      Sterne * -1 as Sterne,
      BildPfad,
      RegionId
    from Hotel
  </DefiningQuery>
</EntitySet>

Der Type für den EntityType:
 <EntityType Name="CustomHotel">
  <Key>
    <PropertyRef Name="HotelId" />
  </Key>
  <Property Name="HotelId" Type="int" Nullable="false" />
  <Property Name="Sterne"  Type="int" />
  <Property Name="Bezeichnung" Type="varchar" />
  <Property Name="BildPfad"  Type="varchar" />
  <Property Name="RegionId"  Type="int" />
</EntityType>

 

Kategorien: