IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Entity Framework Discussion :

EF et stuff for xml path


Sujet :

Entity Framework

  1. #1
    Membre expérimenté
    Avatar de jbrasselet
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Mars 2006
    Messages
    1 022
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 022
    Points : 1 413
    Points
    1 413
    Par défaut EF et stuff for xml path
    Bonjour,

    J'ai une base de données assez complexe. Pour faire simple, j'ai une table Component qui est liée (entre autres) à deux tables de contacts (It et Bo)
    J'aimerais en une seule requête ramener mes components avec la concaténation des It dans une colonne et la concaténation des Bo dans une autre.
    Le but est d'éviter de faire des boucles dans le C# pour formater tout cela et gagner en performance (enfin j'espère)

    J'ai vu hier l'utilisation de la fonction stuff avec for xml path. Cela correspond à mon besoin.

    Mais il semble que Entity framework n'aime pas le for xml path lorsque j'exécute ma requête.

    Quelqu'un aurait-une solution ou une piste ?

    Exemple de requête :
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    SELECT DISTINCT TCD.CartoEntry_Key AS CartoEntryId ,
      TCD.CartoEntry                   AS Code ,
      TCD.CartoEntry_CodBasicat        AS CartoEntryBasicat ,
      CASE
        WHEN TRS.Label_FR IS NULL
        THEN TRS.Label_EN
        ELSE TRS.Label_FR
      END                                 AS CartoEntryStatus,
      TCD.CartoEntry_Object_Type          AS CartoEntryObjectType ,
      TCD.CartoEntry_Origin               AS CartoEntryOrigin ,
      TRMD.Manager_Development_Department AS DevelopmentOrganizationOrganization ,
      TRBOD.BO_Department_Department      AS MainBusinessOwnerOrganization,
        ITCONTACT = stuff((select tlcc.Contact_First_Name+' '+tlcc.Contact_Last_Name+','+tlcc.Contact_Email+','+tlcc.Contact_Department+','+tlcc.Contact_Role+','+trcr.Role_EN+';' from 
    							 T_Link_CartoEntry_Contact as tlcc inner join T_Ref_Contact_Role  as trcr on tlcc.Contact_Role=trcr.Contact_Role
    						where tlcc.CartoEntry = TCD.CartoEntry and trcr.ShowInSummary=1
    						order by tlcc.Contact_Last_Name, tlcc.Contact_First_Name for xml path('')),1,0,''), 
      BOCONTACT = stuff((select tlccbo.Contact_Business_Owner_First_Name+' '+tlccbo.Contact_Business_Owner_Last_Name+','+tlccbo.Contact_Business_Owner_Email+','+tlccbo.Contact_Business_Owner_Department+','+tlccbo.Contact_Business_Owner_Role+','+trbor.Label_EN+';' from 
    							 T_Link_CartoEntry_Contact_Business_Owner as tlccbo inner join T_Ref_Business_Owner_Role as trbor on tlccbo.Contact_Business_Owner_Role=trbor.Business_Owner_Role
    						where tlccbo.CartoEntry = TCD.CartoEntry and trbor.ShowInSummary=1
    						order by tlccbo.Contact_Business_Owner_Last_Name, tlccbo.Contact_Business_Owner_First_Name for xml path('')),1,0,'')
    FROM T_CartoEntry_Description         AS TCD
    INNER JOIN T_CartoEntry_Organization  AS TCO
    ON TCD.CartoEntry=TCO.CartoEntry
    LEFT OUTER JOIN t_ref_business_subdomain AS TRBS
    ON TCD.cartoentry_business_subdomain=TRBS.Business_subdomain
    AND TCD.cartoentry_business_domain  =TRBS.Business_domain
    LEFT OUTER JOIN t_ref_business_domain AS TRBD
    ON TRBS.business_domain=TRBD.Business_domain
    LEFT OUTER JOIN T_REF_Status AS TRS
    ON TCD.CartoEntry_Status = TRS.status
    LEFT OUTER JOIN T_Ref_Business_Owner_Department AS TRBOD
    ON TCO.CartoEntry_BO_Department = TRBOD.BO_Department_Email
    LEFT OUTER JOIN T_Ref_Manager_Development AS TRMD
    ON TCO.CartoEntry_Manager_Development = TRMD.Manager_Development_Email
    WHERE TCD.CartoEntry_Status NOT LIKE 'Workspace'
    AND (TCD.CartoEntry_Status = 'Development'
    OR TCD.CartoEntry_Status   = 'Think'
    OR TCD.CartoEntry_Status   = 'Production')
    AND ((TCD.CartoEntry LIKE '%carto%')
    OR (TCD.CartoEntry_Acronym_Explanation LIKE '%carto%'))
    ORDER BY Code
    L'urgent est fait, l'impossible est en cours, pour les miracles prévoir un délai.

  2. #2
    Invité
    Invité(e)
    Par défaut
    Pour un objet Component donné combien d'objets It et combien d'objets Bo peut-on avoir en moyenne ou au maximum ?

  3. #3
    Membre expérimenté
    Avatar de jbrasselet
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Mars 2006
    Messages
    1 022
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 022
    Points : 1 413
    Points
    1 413
    Par défaut
    Il n'y a pas de limite normalement.
    Pour les IT aujourd'hui on va de 0 à 18
    Pour les BO de 0 à 45
    L'urgent est fait, l'impossible est en cours, pour les miracles prévoir un délai.

  4. #4
    Invité
    Invité(e)
    Par défaut
    C'est quand même beaucoup comme quantité. Une solution est de faire tout le travail côté SGBDR à travers une procédure stockée, l'importer puis utiliser un type complexe comme type de retour

  5. #5
    Membre expérimenté
    Avatar de jbrasselet
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Mars 2006
    Messages
    1 022
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 022
    Points : 1 413
    Points
    1 413
    Par défaut
    Je me suis débrouillé en utilisant une vue qui gère les contacts par component et je fais une simple jointure ensuite.

    Merci de ton aide
    L'urgent est fait, l'impossible est en cours, pour les miracles prévoir un délai.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Best API for XML
    Par abdessami3e dans le forum Format d'échange (XML, JSON...)
    Réponses: 1
    Dernier message: 28/08/2007, 23h28
  2. [SQL SERVER 2000] Récupérer le FOR XML
    Par Madinico dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 27/07/2007, 17h04
  3. Réponses: 2
    Dernier message: 08/12/2006, 15h29
  4. Réponses: 1
    Dernier message: 21/11/2006, 13h28
  5. [FOR XML] XML --> Varchar
    Par Yann dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 03/11/2004, 21h19

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo