ssdl view et TPH
Ce post s'inspire d'un post précédent "EF : Comment faire de l'Entity Splitting avec des PK différentes ?"
L'idée ici est la suivante. On a une table Employee avec 3 colonnes : EmployeeId (PK), EmployeeName et EmployeeManager (FK vers EmployeeId).
De là, je voudrais générer avec EDM deux entity types : Employee et Manager avec Manager héritant d'Employee.
Comment faire cela ?
L'idée est d'utiliser une ssdl view pour faire du TPH.
Il suffit de rajouter le code suivant dans le ssdl :
<EntitySet Name="EmployeeWithManagerStatus" EntityType="TestModel.Store.EmployeeWithManagerStatus">
<DefiningQuery>
SELECT EmployeeID, CAST(CASE WHEN EmployeeId IN (SELECT EmployeeManager FROM EmployeesWithManager) THEN 1 ELSE 0 END AS BIT) as IsManager
FROM EmployeesWithManager
</DefiningQuery>
</EntitySet>
<EntityType Name="EmployeeWithManagerStatus">
<Key>
<PropertyRef Name="EmployeeId" />
</Key>
<Property Name="EmployeeId" Type="int" Nullable="false" />
<Property Name="IsManager" Type="bit" />
</EntityType>
A ce stade, tout le travail est quasiment fait. Il suffit alors de rajouter une entité Manager, de rajouter l'héritage entre Manager et Employee puis de mapper l'entity type Manager sur notre vue ssdl. En dernier lieu, il suffit de rajouter une condition sur le mapping en précisant que pour les Managers, la colonne IsManager = true.
Et voilà, le tour est joué. Sympa non ?
Ce post vous a plu ? Ajoutez le dans vos favoris pour ne pas perdre de temps à le retrouver le jour où vous en aurez besoin :