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

Entity Framework Discussion :

Recherche multi critères


Sujet :

Entity Framework

  1. #1
    Membre confirmé
    Homme Profil pro
    Développeur Full-stack
    Inscrit en
    Novembre 2010
    Messages
    372
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Développeur Full-stack

    Informations forums :
    Inscription : Novembre 2010
    Messages : 372
    Points : 489
    Points
    489
    Par défaut Recherche multi critères
    Bonjour,
    Je souhaiterais faire une recherche multi-critères sur un objet Agent de mon projet:
    -Agent(AgentMatricule, Photo,IdentifiantCivilite, Nom, DateNaissanceAgent, LieuNaissanceAgent, EmpreinteIndexDroitAgent ,DateEmbauche, SexeAgent, AncienneteAgent, Grade,Login, MotDepasse, DateCreationMotdePasse ,DateDernièreConnexion, DateDernièreDeconnexion, AgentGroupe, AgentEquipe,TelephoneAgent,EmailAgent).

    Mes recherches doivent porter sur 6 attributs à savoir AgentMatricule (string), Nom (string),
    Grade (int), AgentEquipe (string),TelephoneAgent (string), NiveauAnglais
    , tous renseignés depuis les champs correspondants. Et chacun de ces champs peut -être renseigné ou non.
    Le problème est que en faisant avec des conditions if, ça devient fastidieux. Alors, j'aimerais savoir qui a une idée d'une autre façon plus facile à coder?

    Si, oui une indication sera la bienvenue.
    La recherche de la connaissance est une Lumière qui apaise le Cœur.
    Si une réponse vous a été utile , n'oubliez pas de voter en cliquant sur:.

  2. #2
    Membre confirmé
    Homme Profil pro
    Développeur Full-stack
    Inscrit en
    Novembre 2010
    Messages
    372
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Développeur Full-stack

    Informations forums :
    Inscription : Novembre 2010
    Messages : 372
    Points : 489
    Points
    489
    Par défaut
    Bonjour à tous,

    J'ai pu élaborer avec de l'aide une procédure de recherche que je nomme ici RechercherAgent . Maintenant, il ne reste qu'à affecter les paramètres de recherches et effectuer les recherches depuis les sources fournies de la Base de Données, en somme charger le tableau depuis la Base de Données pour effectuer un tri selon mes critères définis. Ensuite afficher les Données filtrées, si elles existent ou pas, dans ma GridView (nommée gdvAgents) depuis ma BD. Mon Application est de type 3 tiers. L' IU WebForm, la BLL (AgentBLL dans mon cas) et la DAL (AgentDAL dans mon cas).

    Voici ma procédure de recherche:
    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
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    public static Agent [] RechercherAgent(Agent[] agents, string aMatriculeAgent, string aNomAgent, string aNumTelephone,string aEquipe, int aGrade,int aNiveauLangue)
            {
                IEnumerable<Agent>AgentFiltrés;
     
                AgentFiltrés = agents;
     
     
     
     
                if(aMatriculeAgent !=null)
                {
                    AgentFiltrés.Where(a=>a.AgentMatricule ==aMatriculeAgent);
                }
     
                if (aNomAgent != null)
                {
                    AgentFiltrés.Where(a => a.Nom == aNomAgent);
                }
     
                if (aNumTelephone != null)
                {
                    AgentFiltrés.Where(a => a.TelephoneAgent == aNumTelephone);
                }
     
                if (aEquipe != null)
                {
                    AgentFiltrés.Where(a => a.AgentEquipe == aEquipe);
                }
     
                if (aNiveauLangue != null)
                {
                    AgentFiltrés.Where(a => a.NiveauAnglais == aNiveauLangue);
                }
     
     
                return AgentFiltrés.ToArray();
     
     
            }
    Comment pourrais-je intégrer une source au tableau Agent [] depuis la BD et ensuite afficher le résultat dans ma gridview?

    Cordialement.
    La recherche de la connaissance est une Lumière qui apaise le Cœur.
    Si une réponse vous a été utile , n'oubliez pas de voter en cliquant sur:.

  3. #3
    Membre confirmé
    Homme Profil pro
    Développeur Full-stack
    Inscrit en
    Novembre 2010
    Messages
    372
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Développeur Full-stack

    Informations forums :
    Inscription : Novembre 2010
    Messages : 372
    Points : 489
    Points
    489
    Par défaut
    Résolu enfin:
    Ne pas confondre et .

    Voici mon code de recherche:
    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
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
     public static Agent [] RechercherAgent(string aMatriculeAgent, string aNomAgent, string aNumTelephone,string aEquipe, int aGrade,int aNiveauLangue)
            {
                IEnumerable<Agent>AgentFiltrés;
     
                AgentFiltrés = ContexteDAO.ContexteDonnees.Agents;
     
     
     
     
                if (!string.IsNullOrEmpty(aMatriculeAgent))
                {
                   AgentFiltrés = AgentFiltrés.Where(a=>a.AgentMatricule.Contains(aMatriculeAgent));
                }
     
                if (!string.IsNullOrEmpty(aNomAgent))
                {
                    AgentFiltrés = AgentFiltrés.Where(a => a.Nom.Contains(aNomAgent));
                }
     
                if (!string.IsNullOrEmpty(aNumTelephone))
                {
                    AgentFiltrés = AgentFiltrés.Where(a => a.TelephoneAgent.Contains(aNumTelephone));
                }
     
                if (!string.IsNullOrEmpty(aEquipe))
                {
                    AgentFiltrés = AgentFiltrés.Where(a => a.AgentEquipe.Contains(aEquipe));
                }
     
                if (aGrade != 0)
                {
                    AgentFiltrés = AgentFiltrés.Where(a => a.Grade.Equals(aGrade));
                }
     
                if (aNiveauLangue != 0)
                {
                    AgentFiltrés = AgentFiltrés.Where(a => a.NiveauAnglais.Equals(aNiveauLangue));
                }
     
     
                return AgentFiltrés.ToArray();
     
     
            }
    Son appel:
    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
    protected void BtRechercher_Click(object sender, EventArgs e)
            {
     
     
                RechercherAgent(txtMatricule.Text.Trim(), txtNomAgent.Text.Trim(), txtNumeroTelephone.Text.Trim(), (DDL_Equipe.SelectedValue), Convert.ToInt32(DDL_Grade.SelectedValue), Convert.ToInt32(DDL_Langue.SelectedValue));
     
                var source = new BindingSource();
     
     
                foreach (var oAgent in RechercherAgent( txtMatricule.Text.Trim(), txtNomAgent.Text.Trim(), txtNumeroTelephone.Text.Trim(), (DDL_Equipe.SelectedValue), Convert.ToInt32(DDL_Grade.SelectedValue), Convert.ToInt32(DDL_Langue.SelectedValue)))
                {
     
                    source.Add(oAgent);
                }
     
    //chargement gridView 
                gdvAgents.DataSource = source;
                gdvAgents.DataBind();
    }
    Merci.
    La recherche de la connaissance est une Lumière qui apaise le Cœur.
    Si une réponse vous a été utile , n'oubliez pas de voter en cliquant sur:.

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

Discussions similaires

  1. [MySQL] Recherche multi-critères ou un seul
    Par jack1234 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 14/12/2005, 08h56
  2. Recherche multi-critères
    Par PAUL87 dans le forum Access
    Réponses: 66
    Dernier message: 13/12/2005, 12h12
  3. problème SQL avec le tutoriel recherche multi critère
    Par qbihlmaier dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 05/12/2005, 19h33
  4. problème avec résultat de recherche multi-critères
    Par audrey_desgres dans le forum Access
    Réponses: 2
    Dernier message: 23/06/2005, 11h00
  5. Procédure stockée: recherche multi-critères
    Par biroule dans le forum MS SQL Server
    Réponses: 11
    Dernier message: 01/09/2004, 16h02

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