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

Silverlight Discussion :

Anonymous Type :/


Sujet :

Silverlight

  1. #1
    Membre averti
    Inscrit en
    Avril 2009
    Messages
    41
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 41
    Par défaut Anonymous Type :/
    Bonjour à tous, c'est re moi.

    Voila, j'essaye de faire des belle requête (linq to sql) pour remplir mon datagrid "dg"
    Mais je n'y arrive pas, cela me met "Anonymous type#1". Si quelqu'un peut m'aider SVP.

    Voila ma requête :

    Code : 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
            [OperationContract]
            public List<string> GetResultRechercheAvancee(string lettre)
            {
                DataClasses1DataContext data = new DataClasses1DataContext();
     
                var req = (from e in data.table1
                           join a in data.table2
                           on e.id equals a.id
                           join c in data.table3
                           on e.id equals c.id
                           where e.Nom.StartsWith(lettre)
                           orderby e.Nom
                           select new {e.ID, e.Code , e.Nom, c.Commune, a.Tel, a.Mob});
     
     
     
                return req;
            }
    Et je renvoi donc cela sur mon datagrid.itemsource.
    Ha, en debugant, je retrouve bien des résultats dans req.

    Encore merci a vous

  2. #2
    Invité
    Invité(e)
    Par défaut
    Salut,

    Ta requête me semble incorrecte.

    Ta fonction doit retourner une List<string> alors que ta requête requête Linq To SQL renvoie une collection d'objet d'un type anonyme.

    Soit c'est moi qui ne comprends le Linq To SQL soit c'est toi qui t'es trompé sur la valeur de retour de ta fonction GetResultRechercheAvancee.

  3. #3
    Membre averti
    Inscrit en
    Avril 2009
    Messages
    41
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 41
    Par défaut
    Je pencherais pour la deuxième solution ^^

    Je suis encore très novice en linq to sql.

    Que dois-je mettre comme valeur de retour?comment?

    Marci bien de votre aide

  4. #4
    Rédacteur
    Avatar de Thomas Lebrun
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    9 161
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 9 161
    Par défaut
    Citation Envoyé par h2s84 Voir le message
    Ta fonction doit retourner une List<string> alors que ta requête requête Linq To SQL renvoie une collection d'objet d'un type anonyme.
    +1 avec cette remarque

  5. #5
    Membre averti
    Inscrit en
    Avril 2009
    Messages
    41
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 41
    Par défaut
    J'oubliais que même si je fais

    Sa ne marche po ... Je croix que je m'enfonce ^^

  6. #6
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par climero51 Voir le message
    J'oubliais que même si je fais

    Sa ne marche po ... Je croix que je m'enfonce ^^

    Essaye de mettre ça : (si tu ne veux pas changer la valeur de retour de la fonction)

    Code : 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
    [OperationContract]
            public List<string> GetResultRechercheAvancee(string lettre)
            {
                DataClasses1DataContext data = new DataClasses1DataContext();
     
                var req = (from e in data.table1
                           join a in data.table2
                           on e.id equals a.id
                           join c in data.table3
                           on e.id equals c.id
                           where e.Nom.StartsWith(lettre)
                           orderby e.Nom
                           select e.Nom); // Je pense que tu effectue une recherche sur le nom donc mieux vaut renvoyer cette proprieté non ?
     
     
     
                return req.ToList();
            }
    Avec ce code, ça doit marcher ..

  7. #7
    Membre averti
    Inscrit en
    Avril 2009
    Messages
    41
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 41
    Par défaut
    Sa aurait été plus simple mais il faut que je récupère, les autres informations aussi :/

  8. #8
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par climero51 Voir le message
    Sa aurait été plus simple mais il faut que je récupère, les autres informations aussi :/
    Ok. Tu veux renvoyer quoi au fait ? Tu veux que ta fonction te renvoie une collection d'objet Person ou Client ou d'un type que toi t'as créé sans passé par les types anonymes ?

    Si par exemple tu veux une collection d'objet du type Person alors
    1. tu change le type de retour de ta fonction en List<Person>
    2. Ensuite tu mets le code suivant comme implémentation de ta fonction
      Code : Sélectionner tout - Visualiser dans une fenêtre à part
      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
      15
      DataClasses1DataContext data = new DataClasses1DataContext();
       
                  var req = (from e in data.table1
                             join a in data.table2
                             on e.id equals a.id
                             join c in data.table3
                             on e.id equals c.id
                             where e.Nom.StartsWith(lettre)
                             orderby e.Nom
                             select new Person ()
      { ID =e.ID, Code = e.Code , Nom = e.Nom, Commune = c.Commune, Tel = a.Tel, Mod = a.Mob}); 
       
       
       
                  return req.ToList();


    Essaye ça voir ?

Discussions similaires

  1. datagrid avec anonymous type
    Par zoro007 dans le forum Windows Presentation Foundation
    Réponses: 2
    Dernier message: 21/08/2011, 15h26
  2. linq et reporting services - types anonymes
    Par boby62423 dans le forum Linq
    Réponses: 0
    Dernier message: 03/02/2009, 12h06
  3. [C# 3]Passer un type anonyme à une fonction
    Par NicolasJolet dans le forum C#
    Réponses: 2
    Dernier message: 10/09/2008, 16h17
  4. Linq, type anonyme et redondance
    Par neptune dans le forum Framework .NET
    Réponses: 2
    Dernier message: 25/06/2008, 10h49
  5. [collection] Type anonyme + IEnumerable
    Par ZaaN dans le forum C#
    Réponses: 6
    Dernier message: 08/04/2008, 15h03

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