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

ASP.NET MVC Discussion :

Affichage de plusieurs champs d'une requête


Sujet :

ASP.NET MVC

  1. #1
    Membre du Club
    Inscrit en
    Novembre 2006
    Messages
    79
    Détails du profil
    Informations personnelles :
    Âge : 46

    Informations forums :
    Inscription : Novembre 2006
    Messages : 79
    Points : 54
    Points
    54
    Par défaut Affichage de plusieurs champs d'une requête
    Bonjour,

    J'ai réussi hier à affiché un champ d'une table dans ma page View, depuis le Controller.
    Fichier HomeController.cs
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
     ObjectQuery<FXTB_CONTRACT_MASTER> fxtb_contract_master = _entities.FXTB_CONTRACT_MASTER;
     
     var requete = from fcm in fxtb_contract_master where fcm.BOOKING_DATE_TIME == maDate select  fcm.CONTRACT_REF_NO;
     
     
    List<string> maRequete = new List<string>();
    maRequete = (List<string>) requete.ToList();
    Ca fonctionne.

    Mais maintenant, je chercher à afficher 2 champs ou plus.
    Du coup, mon objet List de ne peu plus être de type <string>
    Mais je n'arrive pas à le caster.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    var requete = from cc in cstb_contract where cc.BOOK_DATE == maDate select new { cc.CONTRACT_REF_NO, cc.BOOK_DATE };
                ViewData["Requete"] = (IList < CSTB_CONTRACT >) requete.ToList();

    J'ai une erreur
    Impossible d'effectuer un cast d'un objet de type 'System.Collections.Generic.List`1[<>f__AnonymousType1`2[System.String,System.Nullable`1[System.DateTime]]]' en type 'System.Collections.Generic.IEnumerable`1[Operations.Models.CSTB_CONTRACT]'.

  2. #2
    Membre actif
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2010
    Messages
    119
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2010
    Messages : 119
    Points : 202
    Points
    202
    Par défaut
    bonjour,
    Pourquoi ne retournes tu pas ton objet ou ta liste d'objet complète à une vue fortement typé puis après dans ta vue tu choisi quel champ tu veut afficher ou pas??
    Pour ton problème de cast je pense que le probleme vient du fait que tu ne récupère pas ton objet en entier dans ta requête. Dans la liste il attend un objet de type CSTB_CONTRACT mais tu lui donne autre chose donc il est pas content.
    J'aurai plutôt fait quelque chose comme ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    var requete = (from cc in cstb_contract where cc.BOOK_DATE == maDate select cc).toList() ;
    J'espère t'avoir aidé.
    cordialement

  3. #3
    Membre expérimenté
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2007
    Messages
    871
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Février 2007
    Messages : 871
    Points : 1 498
    Points
    1 498
    Par défaut
    Salut,

    Pour ton problème de cast:
    Dans ta requête il faut que tu génères cette liste d'objets au lieu d'un type anonyme:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    var requete = from cc in cstb_contract 
    where cc.BOOK_DATE == maDate
    select new CSTB_CONTRACT 
    {
        CONTRACT_REF_NO = cc.CONTRACT_REF_NO,
        BOOK_DATE = cc.BOOK_DATE
     };
    ViewData["Requete"] = requete.ToList();
    Et voila,

  4. #4
    Membre du Club
    Inscrit en
    Novembre 2006
    Messages
    79
    Détails du profil
    Informations personnelles :
    Âge : 46

    Informations forums :
    Inscription : Novembre 2006
    Messages : 79
    Points : 54
    Points
    54
    Par défaut C'est ok pour récupérer une table
    Merci,

    Ca fonctionne effectivement.

    Voici ma requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
                ViewData.Model = _entities.CSTB_CONTRACT.ToList();
                ViewData.Model = (from m in _entities.CSTB_CONTRACT where m.BOOK_DATE == maDate select m).ToList();
    Merci beaucoup.

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

Discussions similaires

  1. Renvoi de plusieurs champs dans une requête
    Par PROJECT-AURORA dans le forum Langage SQL
    Réponses: 2
    Dernier message: 10/12/2013, 14h45
  2. Autocomplétion avec affichage de plusieurs champs dans une liste
    Par chewing-gum dans le forum ASP.NET Ajax
    Réponses: 1
    Dernier message: 01/02/2012, 11h17
  3. [Requête] plusieurs champs dans une même table ayants la même source
    Par Christophe93250 dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 25/04/2006, 16h18
  4. Réponses: 3
    Dernier message: 25/04/2006, 10h30
  5. Ramener plusieurs champs dans une sous requête...
    Par David.V dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 12/01/2005, 07h54

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