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

Linq Discussion :

Problème de création requête en LINQ


Sujet :

Linq

  1. #1
    Membre confirmé
    Inscrit en
    Mai 2006
    Messages
    55
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 55
    Par défaut Problème de création requête en LINQ
    Bonjour,

    Je suis nouveau pour tout ce qui concerne le LINQ et j'ai une requête que je dois effectué mais je n'y arrive pas, peut-être une personne trouvera, je m'explique :

    Je dois parcourir une liste de contrats et la comparer à une autre. Si un objet contrat est commun (via leurs id) aux deux listes, alors il doit me le dire.
    De plus, il faut que ce contrat ait un statut spécifique passé en paramètre à la requête LINQ.

    Je ne sais pas si vous avez compris mais en gros il me faudrait quelque chose comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    foreach (ContractVO C in listAllContracts)
    {
         // Il faut comparer les id du contrat et non l'objet
         if (listSelectedSentContracts.Contains(C) && C.Status.Equals(ContractStatus.SentToCustomer) || C.Status.Equals(ContractStatus.Signed))
              ALORS JE FAIS UN TRAITEMENT
         else if (C.Status.Equals(ContractStatus.Stock) || C.Status.Equals(ContractStatus.Underway) || C.Status.Equals(ContractStatus.Pending) || (C.Status.Equals(ContractStatus.SentToCustomer) && !listSelectedSentContracts.Contains(C)) && C.StartDate >= cutOffEndDate)
              JE FAIS UN AUTRE TRAITEMENT
    }
    Pour l'instant ce que je fais en LINQ est quelque chose comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    var listSentContracts =    (from list in listSelectedSentContracts
                                       where C.ContractId.Equals(list.CustomerId)
                                       && Status2.Contains((ContractStatus)list.Status)
                                       select list).ToList();
    Mais ça me retourne aucun objet alors qu'il y en a bien un

    Quelqu'un saurait comment faire la même chose que l'exemple donné plus haut en LINQ ?

    Merci d'avance

  2. #2
    Membre chevronné
    Inscrit en
    Octobre 2005
    Messages
    400
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 400
    Par défaut
    Pourrais tu faire deux vérification :

    La liste Status2 est elle bien rempli ?
    Est-il normal que tu compare un identifiant de contrat avec un identifiant de client ?

  3. #3
    Membre confirmé
    Inscrit en
    Mai 2006
    Messages
    55
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 55
    Par défaut
    Oui la liste des statuts étaient bien rempli mais la problème venait du deuxième point que tu soulignais :

    voilà le code LINQ :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    var sentContracts = (from selectedContract in listSelectedSentContracts
    where C.ContractId.Equals(selectedContract.ContractId)
    || Status2.Contains((ContractStatus)selectedContract.Status)
    select selectedContract).FirstOrDefault();
    Merci

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 04/08/2008, 15h35
  2. Réponses: 1
    Dernier message: 01/08/2008, 17h25
  3. Réponses: 7
    Dernier message: 10/02/2008, 11h56
  4. problème de création d'une requête SQL
    Par crushilefou dans le forum Requêtes
    Réponses: 9
    Dernier message: 07/12/2007, 11h59
  5. problème de création de requète sous VBA
    Par Golork dans le forum Access
    Réponses: 4
    Dernier message: 02/06/2006, 14h35

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