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 Discussion :

Définition d'une méthode IfExiste avec plusieurs paramètres


Sujet :

ASP.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2016
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : Pérou

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2016
    Messages : 15
    Par défaut Définition d'une méthode IfExiste avec plusieurs paramètres
    Bonjour,

    Je voudrais définir une méthode JournalExiste() qui prends en paramétre le code du magasin, le mois, et l’année du journal, les recherchent en base de données bdd, et si elle trouve qu'il y a une ligne qui a les memes paramètres elle retourne true sinon false

    Voici mes classes:

    Classe magasin
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
     
        public class Magasin
        {
            public int Id { get; set; }
            [Required]
            public String Nom { get; set; }
            public virtual List<Journal> Journal { get; set; }
     
        }
    Classe Journal
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
     
        public class Journal
        {
            public int Id { get; set; }
            [Required]
            public int Mois { get; set; }
            [Required]
            public int Annee { get; set; }
        }
    j'ai penser a faire ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
     
     public bool JournalExiste(int code, int mois, int annee)
            {
                var journalTrouve = bdd.Journaux.FirstOrDefault(journal => journal.Magasin_Id == code, annee => journal.annee == annee, journal => journal.Mois == mois); // Or ce ne passe pas comme ca, mais je ne sais pas comment m'y prendre
                if (journalTrouve != null)
                {
                  return true;
                }else return false;
            }
    Mes questions sont donc :
    -comment vérifier les trois attributs en même temps ? (mois, annee, et SURTOUT le code magasin ? sachant que magasin a une list<Journal> Journal
    PS: apparemment EntityFramework m'a créer une colonne Magasin_Id...

  2. #2
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2016
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : Pérou

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2016
    Messages : 15
    Par défaut
    Bonsoir,

    Voila j'ai résolu partiellement mes problèmes:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    public bool JournalExiste(int code, int mois, int annee)
    {
    internal var journalTrouve = bdd.Journaux.FirstOrDefault(journal =>
        {
            return journal.Magasin_Id == code && journal.annee == annee && journal.Mois == mois;
        }); // 
        if (journalTrouve != null)
    {
        return true;
    }
    else return false;
    }
    Reste plus qu'a accéder a la variable Magasin_Id.
    C'est une variable qui doit être stocké par la classe magasin, du coup comment devrais je m'y prendre? devrais je faire une extension de la classe Journal ??

  3. #3
    Membre émérite Avatar de Momoth
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mars 2013
    Messages
    318
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2013
    Messages : 318
    Par défaut
    Salut,

    En fait, tu étais pas loin avec ta première requête. Tu n'avais juste pas la bonne syntaxe :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    bdd.Journaux.FirstOrDefault(journal => journal.Magasin.Id == code && journal.Annee == annee && journal.Mois == mois);
    Vu que tu fais juste un test pour savoir si l'objet existe en bdd ou non, tu peux utiliser la méthode Any(expression) plutôt que FirstOrDefault(expression).

    Any() va te retourner le bool qui correspond au if que tu fais juste après, a savoir "Est ce que dans ma liste, il y'a au moins un objet qui répond à ma condition".

    Petite question : Tu développe avec quel IDE (logiciel) ?

  4. #4
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2016
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : Pérou

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2016
    Messages : 15
    Par défaut
    Remercie Momoth,

    Sinon voila la solution avec journalmensuelmagasin.Magasin.Id me retourne une erreur : expression lambda avec un corps ne peut pas etre converti en arborecsence
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
            public bool JournalMensuelMagasinTrouvee(int code, int mois, int annee)
            {
                return bdd.JournauxMensuelsMagasins.Any(journalmensuelmagasin =>
                {
                    return journalmensuelmagasin.Magasin.Id == code && journalmensuelmagasin.Annee == annee && //Erreur
                           journalmensuelmagasin.Mois == mois;
                });
            }
    Je travail avec Miscrosoft Visual Studio 2017

    Ps: Je pense clore un des 2 sujets :/

  5. #5
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2016
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : Pérou

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2016
    Messages : 15
    Par défaut
    C'est bon problèmes résolus,

    Dans un contexte de base de données Linq-To-SQL, on ne peut utiliser que des expressions simples à droite de l'opérateur =>. La raison en est que ces expressions ne sont pas exécutées mais sont converties en SQL pour être exécutées sur la base de données.

    Le code qui suit résout donc mon problème:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
            public bool JournalMensuelMagasinTrouvee(int code, int mois, int annee)
            {
                return bdd.JournauxMensuelsMagasins.Any(journalmensuelmagasin => journalmensuelmagasin.Magasin.Id == code && journalmensuelmagasin.Annee == annee && journalmensuelmagasin.Mois == mois;);
            }
    Voilaa , sujet résolu !

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 06/01/2011, 16h28
  2. Appel d'une fonction avec plusieurs paramètres
    Par kazarn dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 06/06/2009, 18h55
  3. créer une fonction avec plusieurs paramètres
    Par SHERPAE dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 06/01/2009, 17h41
  4. appel d'une méthode avec plusieurs paramètres
    Par soujava dans le forum Débuter avec Java
    Réponses: 2
    Dernier message: 11/05/2008, 23h30
  5. Requête avec plusieurs paramètres d'un même champ d'une table
    Par jb.julien dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 21/08/2007, 09h43

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