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 :

C# requête pour récupérer données de 2 tables associées en many to many?


Sujet :

C#

  1. #1
    Nouveau membre du Club
    Femme Profil pro
    Inscrit en
    Décembre 2011
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 32
    Points : 27
    Points
    27
    Par défaut C# requête pour récupérer données de 2 tables associées en many to many?
    Bonsoir,

    j'ai un soucis avec mon code. J'essaye de récupérer les niveaux de mon entité employé en fonCtion de son username. J'avais tout d'abord créé une List<Acces_level> mais visual me suggérait une Icollection. Mon pb, c'est que je n'arrive pas à récupérer mes données. En effet, le ToList() à la fin de ma requête n'est pas du tout apprécié, j'obtiens le message d'erreur suivant :

    Error 1 Cannot implicitly convert type 'System.Collections.Generic.List<System.Collections.Generic.ICollection<proget.Acess_level>>' to 'System.Collections.Generic.ICollection<proget.DAL.Acess_level>'. An explicit conversion exists (are you missing a cast?)

    Merci pour vos réponses!

    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
     
    public static ICollection<Acess_level> getLevel(string pLogin) 
            {
                ICollection<Acess_level> levels;
     
                using (ModelContext entities = new ModelContext())
                {
     
                    levels = (from employees in entities.Employees
                                where employees.Username == pLogin
                              select employees.Acess_level).ToList();
     
                }
     
                return levels;
     
            }

  2. #2
    Expert confirmé

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2010
    Messages
    2 066
    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 066
    Points : 4 233
    Points
    4 233
    Par défaut
    Ton Acess_level n'est pas le même objet que ton employees.Acess_level.
    Soit tu renvoie une ICollection<employees.Acess_level> ou tu fais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    levels = (from employees in entities.Employees
                                where employees.Username == pLogin
                              select new Acess_level {
     Id= employees.Acess_level.Id,
    Acces=employees.Acess_level.Acces
     
    }).ToList();
    Ca devrait être un truc comme ça.

    Et pourquoi l'avoir mis dans une fonction static.

  3. #3
    Nouveau membre du Club
    Femme Profil pro
    Inscrit en
    Décembre 2011
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 32
    Points : 27
    Points
    27
    Par défaut
    Bonjour Youtpout,


    merci pour ta réponse, j'essaye de la comprendre et de l'appliquer à mon code, je reviens tout à l'heure pour dire ce qu'il en est.

  4. #4
    Nouveau membre du Club
    Femme Profil pro
    Inscrit en
    Décembre 2011
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 32
    Points : 27
    Points
    27
    Par défaut
    Me revoilà,

    je n'ai toujours pas réussi à régler mon pb, j'ai essayé le code que tu m'as donné mais des erreurs persistent . J'ai fait un petit tour sur le net avant de revenir sue le fofo histoire d'en apprendre plus , mais en vain, c'est vraiment dur de trouver un cours facile à comprendre et traitant des bases.

    Je pense que je dois formuler autrement ma question.
    Quand on a 2 tables en association "many to many", (dans mon cas j'ai une table Employee et une table Acces_level), comment faire pour récupérer par ex tous les levels d'un Employee en fonction de son username???

    Si vous avez une petite idée, ce serait cooool, car là, je désespère....


    Merciiiiiii!!

  5. #5
    Expert confirmé

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2010
    Messages
    2 066
    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 066
    Points : 4 233
    Points
    4 233
    Par défaut
    Je n'avais pas compris ce que tu voulais faire la première fois.
    J'ai crée une relation many to many pour faire des tests, donc 3 tables:
    -User (la liste des utilisateurs)
    -Droit (la liste des droits)
    -UserDroit (permettant de faire le lien entre les droits et les utilisateurs)

    j'ai essayé de faire une requête compréhensible pour toi:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
            public ICollection<Droit> GetDroits(string login)
            {
                TestEntities ctx = new TestEntities();
     
                ICollection<Droit> liste;
                liste = (from droit in ctx.Droits
                         from userDroit in ctx.UserDroits
                         from user in ctx.Users
                         where user.Login == login && userDroit.IdUser == user.Id && droit.Id == userDroit.IdDroit
                         select droit).ToList();
     
                return liste;
            }

Discussions similaires

  1. Requête pour récupérer les noms des tables
    Par cendrine15 dans le forum Langage SQL
    Réponses: 1
    Dernier message: 20/04/2012, 00h46
  2. Réponses: 1
    Dernier message: 16/05/2010, 20h30
  3. Réponses: 5
    Dernier message: 14/03/2010, 21h50
  4. Réponses: 1
    Dernier message: 25/11/2008, 11h11
  5. Réponses: 3
    Dernier message: 26/02/2007, 10h14

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