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 :

Liste des classes d'un DataContext


Sujet :

C#

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    444
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 444
    Par défaut Liste des classes d'un DataContext
    Bonjour,

    j'ai créé des classes dans un Datacontext via l'IDE à partir d'une base SQL.
    Si je peux faire des requêtes sur mes classes sans soucis, j'aimerai faire pareil avec le DataContext.

    Pour remplir une listbox avec les données j'utilise une ComboBox que je remplis à la main pour sélectionner la bonne classe. Je voudrai rendre ce bout de code dynamique pour remplir la ComboBox:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
                IEnumerable<DataClasses1DataContext> listeQueryClasses = from DataClasses1DataContext chaqueclasse in moncontext select chaqueclasse;
                foreach (DataClasses1DataContext lclasse in listeQueryClasses)
                    comboBox1.Text = ...
    Enfin si c'est possible.

    Merci.

  2. #2
    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 veux dire les types d'entités ? Ce sont des propriétés du DataContext, donc tu peux les récupérer par réflexion:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    IEnumerable<string> entityClassNames = 
        from p in dataContext.GetProperties()
        let t = p.PropertyType
        where t.IsGenericType
        && t.GetGenericTypeDefinition() == typeof(Table<>)
        select t.GetGenericArguments()[0].Name;
    Il y a sans doute un moyen plus propre, mais ça devrait marcher...

    EDIT: plus simple et plus propre:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    IEnumerable<string> entityClassNames =
        from t in dataContext.Mapping.GetTables()
        select t.MetaType.Type.Name;
    (ou un truc comme ça)

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    444
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 444
    Par défaut
    Citation Envoyé par tomlev Voir le message

    (ou un truc comme ça)
    En fait je voulais récupérer le nom des entités ou des tables (ce qui est un peu la même chose) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    IEnumerable<string> entityClassNames = from t in moncontext.Mapping.GetTables() select t.TableName;
    C'est mochetouille car on récupère le dbo.XXX mais bon comme c'est récurent à chaque table ça a l'avantage de pouvoir se filtrer en 1 seule ligne.

    Merci beaucoup.

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

Discussions similaires

  1. Récupérer la liste des classes d'un package
    Par Coulon Arnaud dans le forum Général Java
    Réponses: 20
    Dernier message: 30/12/2010, 00h04
  2. Connaitre la liste des classes implémentant une interface
    Par luckyvae dans le forum Général Java
    Réponses: 5
    Dernier message: 23/12/2008, 12h10
  3. liste des class java
    Par mitoubra dans le forum Général Java
    Réponses: 2
    Dernier message: 25/01/2008, 10h43
  4. Liste des classes d'un package d'un PlugIn
    Par SpIrIt505050 dans le forum Langage
    Réponses: 2
    Dernier message: 25/07/2007, 15h45
  5. lire la liste des classes d'un package sous Websphere
    Par Coulon Arnaud dans le forum Websphere
    Réponses: 4
    Dernier message: 21/05/2007, 09h22

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