Matthieu Mezil
Les bases d'Entity Data Model
Avec EDM, l'Entity Framework permet d'assurer l'indépendance entre les entités et le modèle de persistance et authorise un mapping très puissant
Par Matthieu Mezil publié le 24/03/2008 à 11:37
 
Une fonction ssdl est soit une procédure stockée, soit une commande sql directement définie dans le ssdl.
Dans EDM, il y a deux types de fonctions ssdl :
  • les fonctions de type Create Update Delete
  • les fonctions de type Read
Pour utiliser des procédures stockées, il faut dans un premier temps les avoir importées dans le modèle (dans la description de la base). Ceci se fait facilement via l'écran « Choose your DataBase Objects » du wizard vu au début.
Dans la version 1 d'EDM, si le développeur souhaite utiliser une function ssdl de type CUD, il est obligé d'utiliser une fonction pour chacune des trois opérations (INSERT, UPDATE, DELETE).
Pour l'exemple, Customer et Member seront réduits (voir le schéma suivant), avec CustomerID définit comme un entier auto-incrémenté côté base.
 
/content/5bdd0f35-3fca-491f-b418-986929ca4dcd/CUD ssdl functions Entities.jpg
 
Dans la fenêtre Mapping Details, il suffit de mapper les paramètres des fonctions ssdl avec les propriétés de l'entité.
 
/content/5bdd0f35-3fca-491f-b418-986929ca4dcd/CUD ssdl functions Mapping.jpg
 
Dans le Insert, la flèche de la colonne Operator est dans l'autre sens pour CustomerID. En effet, c'est bien la base qui va renseigner la propriété et non l'inverse (la valeur étant calculée par la base). Dans le cas présent, la fonction ssdl est la suivante :

INSERT INTO Customers ([Name]) VALUES (@Name)

SELECT SCOPE_IDENTITY() as CustomerID

Pour l'Update, il est possible de définir la version à utiliser : Current ou Original.
Pour Member, supposons que le INSERT effectue préalablement un INSERT dans Customer. De même, supposons que le UPDATE de Member possède le paramètre Name de Customer.
Il va donc falloir mapper via la relation :
 
/content/5bdd0f35-3fca-491f-b418-986929ca4dcd/CUD ssdl functions Mapping with relations.jpg
 
Dans le cas d'un héritage, si la classe de base effectue ses opérations de CUD par fonctions ssdl, il devra en être de même pour ces classes filles et inversement.
Dans ce cas, il va falloir importer la procédure stockée du ssdl (qui décrit la base de données) vers le csdl (qui décrit les entités).
 
/content/5bdd0f35-3fca-491f-b418-986929ca4dcd/Model Browser.jpg
 
Suite à cela, il faut définir le nom de la méthode à créer et le type de retour de celle-ci. Ce type peut être un type de base (string, int, etc.), rien du tout (void) ou une entité définie dans le csdl.
 
/content/5bdd0f35-3fca-491f-b418-986929ca4dcd/Ssdl Select function.jpg
 
Une fois cela effectué, la classe TestEntities (qui hérite de ObjectContext) contient une nouvelle méthode.
 
/content/5bdd0f35-3fca-491f-b418-986929ca4dcd/Model Browser updated.jpg
 

 Commentaires (19) - Les bases d'Entity Data Model 

Discussion démarée par Dadvdadv le 01/09/2008 à 22:57 , 2 commentaire(s).
Discussion démarée par DadvDadv le 14/08/2008 à 00:38 , 15 commentaire(s).
Discussion démarée par Frédéric Decréquy le 05/04/2008 à 12:00 , 2 commentaire(s).

 Dernières Publications      

Utilisation de jQuery avec ASP.NET MVC
  Développer une IHM à page unique avec ASP.NET MVC et jQuery
par Nicolas Moyère posté le 30/06/2008 à 10:28, lu 824 fois, #0
Tags: ASP.NET MVC, Ajax
Windows Media Center et WCF : développez votre maison intelligente
  Le développement d'applications pour Windows Media Center est facilité avec l'arrivée du SDK 5.3. Même si l'on sent un modèle objet bien lourd derrière, il devient plus facile d'exposer les fonctionnalités de WMC sous la forme de services WCF.
par Frédéric Colin posté le 23/06/2008 à 08:04, lu 891 fois, #0
Notions avancées avec Biztalk Server 2006 R2
  Utilisation des notions d'interchange, corrélation et convoi avec BizTalk Server 2006 R2
par Kader Yildirim posté le 09/06/2008 à 08:04, lu 705 fois, #0
Lucene Persistence Engine pour Evaluant Universal Storage Services
  Suite à l'article de Laurent Kempé, voici un moteur de stockage pour EUSS permettant l'indexation d'entités métier avec Lucene.
par Nicolas Penin posté le 01/06/2008 à 23:38, lu 1091 fois, #1
Tags: C#, Linq
XMLA Trivia : Découverte du XMLA
  Le XMLA (XML for Analysis) est un langage normalisé par plusieurs éditeurs BI pour simplifier l'accès aux données aux cubes et aux métadonnées des bases multidimensionnelles.
par Renaud Harduin posté le 25/05/2008 à 11:57, lu 1008 fois, #1
Exploiter les données CSV via Linq en toute simplicité
  A partir du requêteur dynamique fourni en exemple avec Visual Studio 2008, nous allons essayer de remplir les propriétés d'un ensemble d'objets à partir des données d'un fichier CSV. Nous enrichirons aussi le parseur de nos propres fonctions.
par Frédéric Mélantois posté le 17/05/2008 à 11:41, lu 2785 fois, #0
Comment manipuler simplement le contenu d'un fichier WordML ?
  Manipulations autour du format WordML
par Fabien Reinle posté le 14/05/2008 à 23:55, lu 1405 fois, #0
Polymorphisme et contrats de données WCF
  WCF aborde les types polymorphes du point de vue de la sérialisation. En effet, la connaissance du type réel potentiel est rendue nécessaire dès la description du contrat de données. Une fois n'est pas coutume, j'ai réalisé l'exemple en VB.NET.
par Frédéric Colin posté le 14/05/2008 à 08:40, lu 2931 fois, #2

 Dernières Actualités      

Reprise du projet Reflector par RedGate
  La nouvelle était connue depuis quelques jours par les développeurs de plugins, mais c’est désormais officiel : Lutz Roeder, le responsable de Reflector confie à la société RedGate le futur du projet....
Microsoft publie Visual Studio 2008 Service Pack 1
  Il est recommandé d’utiliser l’outil Visual Studio 2008 Service Pack preparation Tool avant de faire l’installation du Service Pack si vous avez installé des versions béta sur votre machine. Une fois que...
Tags: Framework .NET, Visual Studio 2008
Evaluant dévoile ses sources
  L'ensemble des projets R&D réalisés par les consultants de la SSII Evaluant sont en cours de publication sur CodePlex . L'objectif est de les centraliser et surtout d'augmenter leur visibilité. L'avantage...
Le Silverlight Tour en français!
  Le Silverlight Tour passe maintenant dans les pays francophones! En effet RunAtServer Consulting est partenaire du Silverlight Tour pour la gestion de cette formation Silverlight en français à commencer...
Microsoft publie ASP.NET AJAX 4.0 CodePlex Preview 1
  Cette pré-version contient les améliorations suivantes: Client-side template rendering Declarative instantiation of behaviors and controls DataView control Markup extensions Bindings Vous pouvez en lire...
Tags: Ajax
Deep Earth – Une belle utilisation de Virtual Earth et de Silverlight Deep Zoom
  Ce projet très intéressant est disponible sur Codeplex et vous pouvez voir une démo sur la page suivante . Bien entendu comme touts les projets sur Codeplex vous avez accès aux sources....
Tags: Silverlight