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

C# Discussion :

Requete Linq vers un Xelement vide [Débutant]


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2012
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2012
    Messages : 4
    Par défaut Requete Linq vers un Xelement vide
    Bonjour,
    Voila j'ai un probleme j'essai de faire une requete linq vers un Xelement qui se trouve etre vide parfois et le probleme est que justement quand cet Xelement se trouve etre vide le linq ne peut se continuer: <"mon_element"/> voila donc ce que j'ai dans le xml comment
    dois-je m'y prendre pour faire en sorte que si le Xelement ne contient rien, la requete me renvoi un element nul ou un truc du genre mais en tout cas faire quelque chose pour permettre au programe de fonctionner quelque soit le Xelement?
    C#

  2. #2
    Membre Expert

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2010
    Messages
    2 067
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Novembre 2010
    Messages : 2 067
    Par défaut
    regarde cette conversation:
    http://www.developpez.net/forums/d11...nce-exception/

    je pense que ton problème est similaire au sien

  3. #3
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Par défaut
    Montre le code que tu as déjà écrit, et l'endroit qui pose problème...

  4. #4
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2012
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2012
    Messages : 4
    Par défaut
    Voila mon code
    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
    19
    20
    21
    mroom = (from r in RoomRoot.Elements()
                             where Convert.ToInt32(r.Element("Room_code").Value) == search
                             select new Room(Convert.ToInt32(r.Element("Room_code").Value), 
                                 Convert.ToInt32(r.Element("Room_bed_num").Value),
                                 (Room.Room_Type)Convert.ToInt32(r.Element("Room_type").Value), 
                                 Convert.ToInt32(r.Element("Room_price").Value))
                             {
                                 //code_Room = Convert.ToInt32(r.Element("Room_code").Value),
                                 //Bed_num = Convert.ToInt32(r.Element("Room_bed_num").Value),
                                 //Type = (Room.Room_Type)Convert.ToInt32(r.Element("Room_type").Value),
                                 Sea_view = Convert.ToBoolean(r.Element("Room_sea_view").Value),
                                 Blackglass = Convert.ToBoolean(r.Element("Room_blackglass").Value),
                                 Safe = Convert.ToBoolean(r.Element("room_safe").Value),
                                 Keydoor = Convert.ToBoolean(r.Element("Room_keydoor").Value),
                                 Balcony = Convert.ToBoolean(r.Element("Room_balcony").Value),
                                 Minibar = Convert.ToBoolean(r.Element("Room_minibar").Value),
                                 Price_r = Convert.ToInt32(r.Element("Room_price").Value),
                                 //Ajouter la list de datetime
                                 Reserv_date = (from x in r.Elements("Room_dates")
                                                select Convert.ToDateTime(x.Element("Day_reserved").Value)).ToList<DateTime>()
                             }).FirstOrDefault();

    Et mon fichier XML pour comprendre le probleme:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    <Rooms>
      <Room>
        <Room_code>100</Room_code>
        <Room_bed_num>4</Room_bed_num>
        <Room_type>1</Room_type>
        <Room_sea_view>false</Room_sea_view>
        <Room_blackglass>false</Room_blackglass>
        <room_safe>false</room_safe>
        <Room_keydoor>true</Room_keydoor>
        <Room_balcony>true</Room_balcony>
        <Room_minibar>false</Room_minibar>
        <Room_dates />
        <Room_price>100</Room_price>
      </Room>
    Comme on peut le voir il n'y a rien dans la balise <Room_dates>
    Donc en lançant le debogueur je trouve l'erreur que justemet la balise est vide donc existe-t-il une sorte de .ToListOrDefault?

    Merci

  5. #5
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Par défaut
    Tu peux faire ça :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    ...
    Reserv_date = (from x in r.Elements("Room_dates")
                           let dayElement = x.Element("Day_reserved")
                           where dayElement != null
                           select Convert.ToDateTime(dayElement.Value)).ToList()
     
    ...
    Comme ça tu filtres les éléments Room_dates qui n'ont pas d'élément Day_reserved.

    Au passage, inutile de préciser ToList<DateTime>() : le type DateTime est inféré automatiquement car la requête renvoie un IEnumerable<DateTime>

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

Discussions similaires

  1. Réponses: 8
    Dernier message: 24/06/2009, 14h41
  2. Réponses: 3
    Dernier message: 05/11/2008, 10h24
  3. Exporter des données d'un requete SQL vers excel (csv)
    Par PrinceMaster77 dans le forum ASP
    Réponses: 9
    Dernier message: 08/10/2005, 22h28
  4. Portage requete Access vers SQL Server (Iif)...
    Par cmousset dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 14/06/2005, 16h38
  5. Requete Access vers oracle
    Par twizell dans le forum Oracle
    Réponses: 16
    Dernier message: 22/11/2004, 16h47

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