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

Peut-on personnaliser ses requêtes avec un CRUD généré ?


Sujet :

ASP.NET MVC

  1. #1
    Nouveau membre du Club
    Inscrit en
    Janvier 2011
    Messages
    71
    Détails du profil
    Informations forums :
    Inscription : Janvier 2011
    Messages : 71
    Points : 31
    Points
    31
    Par défaut Peut-on personnaliser ses requêtes avec un CRUD généré ?
    Bonjour!
    j'ai créer un controller avec ASP.NET MVC 3 avec génération du CRUD d'entity framework. je voudrais pouvoir faire d'autres requêtes d'insertion vers les tables qui ne sont pas directement liées au controller. par exemple, j'ai deux tables Entrees et Stocks. j'ai crée un controller EntreeController qui me permet d'ajouter toutes mes entrées dans la BD. or je voulais qu'en insérant les données dans la table Entrées, que je puisse également mettre à jour ma table Stocks. comment faire pour gérer ceci?
    voici quelques unes de mes tables:
    Entrees(identree, idarticle, quanite, dateentree)
    Stocks(idstock, idarticle, qte)
    Articles(idarticle, designation, prix)
    Merci d'avance!

  2. #2
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2011
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2011
    Messages : 6
    Points : 6
    Points
    6
    Par défaut
    Bonjour Beaudelaire,

    Je n'ai pas très bien compris ton problème, tu souhaite pouvoir ajouter une entité stock et une entité entrée en même temps à partir de la même action?

  3. #3
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Points : 13 314
    Points
    13 314
    Par défaut
    Citation Envoyé par beaudelaire Voir le message
    voici quelques unes de mes tables:
    Entrees(identree, idarticle, quanite, dateentree)
    Stocks(idstock, idarticle, qte)
    Articles(idarticle, designation, prix)
    Merci d'avance!
    Le calcul du stock semblant (a priori) dérivé uniquement des entrées et sorties, il ressort donc, pour moi, du SGBD, pas de l'application cliente.

    => PS et/ou Triggers.

    Je ne réponds pas aux questions techniques par MP ! Le forum est là pour ça...


    Une réponse vous a aidé ? utiliser le bouton

    "L’ennui dans ce monde, c’est que les idiots sont sûrs d’eux et les gens sensés pleins de doutes". B. Russel

  4. #4
    Nouveau membre du Club
    Inscrit en
    Janvier 2011
    Messages
    71
    Détails du profil
    Informations forums :
    Inscription : Janvier 2011
    Messages : 71
    Points : 31
    Points
    31
    Par défaut
    En fait, Pierre-AlexandreGury a parfaitement compris ma préoccupation. Alors, comment je dois procéder?

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2011
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2011
    Messages : 6
    Points : 6
    Points
    6
    Par défaut
    Tu utilise un repository qui te permet de manipuler les entités de ta base de donnée, ou bien utilise tu directement ton contexte a l’intérieur même de ton controller?
    Si c'est la deuxième solution, je ne vois pas ce qui pourrait t’empêcher de créer un nouvel objet du type souhaité et d'utiliser ton objet contexte pour l'ajouter en base juste avant la méthode savechanges().

    Essaye de me détailler un peu plus ce que tu souhaite faire, le comportement exact que tu souhaite recréer.

  6. #6
    Nouveau membre du Club
    Inscrit en
    Janvier 2011
    Messages
    71
    Détails du profil
    Informations forums :
    Inscription : Janvier 2011
    Messages : 71
    Points : 31
    Points
    31
    Par défaut
    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
     
            // GET: /Entree/Create
     
            public ActionResult Create()
            {
                ViewBag.idMateriel = new SelectList(db.Materiels, "idMateriel", "nomMateriel");
     
                return View();
            } 
     
            //
            // POST: /Entree/Create
     
            [HttpPost]
            public ActionResult Create(Entree entree)
            {
                if (ModelState.IsValid)
                {
                    entree.dateEntree = DateTime.Now;
                    db.Entrees.AddObject(entree);
                    db.SaveChanges();
                    return RedirectToAction("Index");  
                }
                ViewBag.idMateriel = new SelectList(db.Materiels, "idMateriel", "nomMateriel", entree.idMateriel);
     
                return View(entree);
            }
    Comme vous pouvez le voir, voici mon controller : EntreeController
    Ce que je souhaite est de pouvoir insérer les informations à la fois dans la table des Entrees et faire une mise à jour de l’enregistrement dans la table Stocks. Par exemple si la nouvelle entrée concerne 50 vélos, je voudrais qu’en même temps ces 50 vélos s’ajoutent aux vélos restants dans la table Stock(une incrémentation en quelque sorte du stock de l’article vélo). Où dois- je écrire ma requette ?

  7. #7
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2011
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2011
    Messages : 6
    Points : 6
    Points
    6
    Par défaut
    Il vous suffit de rajouter les lignes permettant de faire un update de votre table stock dans cet action :
    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
            [HttpPost]
            public ActionResult Create(Entree entree)
            {
                if (ModelState.IsValid)
                {
                    entree.dateEntree = DateTime.Now;
                    db.Entrees.AddObject(entree);
                    Ici
                    db.SaveChanges();
                    return RedirectToAction("Index");  
                }
                ViewBag.idMateriel = new SelectList(db.Materiels, "idMateriel", "nomMateriel", entree.idMateriel);
     
                return View(entree);
            }
    Vous utilisez du sql server avec entity framework?

  8. #8
    Nouveau membre du Club
    Inscrit en
    Janvier 2011
    Messages
    71
    Détails du profil
    Informations forums :
    Inscription : Janvier 2011
    Messages : 71
    Points : 31
    Points
    31
    Par défaut
    oui j'utilise SQL Server avec Entity Framework. ça peut poser problème? que me conseilles-tu?
    Par rapport à ta réponse, je vais m'y mettre tout de suite. Mais avant, je voulais savoir: puisque je suis dans le controller Entree et que je dois faire des mises à jour sur la table Socks, ça ne posera pas un problème?

  9. #9
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2011
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2011
    Messages : 6
    Points : 6
    Points
    6
    Par défaut
    L'utilisation d'entity framework et sql server ne pose aucun problème.

    Vis à vis de ta question si le fait de mettre a jour une entité de type Stock dans le controller Entree pose problème, et bien cela ne pose aucun problème.

    Par-contre je te conseil de te pencher sur le pattern "repository", ce pattern a pour effet (entre autre) de permettre d'accéder aux entités stockée dans ta base de donnée a travers un objet appelé Repository.

    Par exemple, tu aura une classe StockRepository, qui exposera plusieurs méthodes comme "GetStockById(int id)", "GetStocks()", "DeleteStock(Stock stock)" etc..etc... L'utilisation de ce pattern te permettra donc de centraliser toute tes requêtes linq vers ton contexte entity framework, et donc d’éviter la duplication de celles-ci.

    Je te fais suivre un article intéressant pour que tu puisse te pencher sur ce pattern. Il y à énormément de ressources sur ce sujet sur le net, je te laisse donc continuer ton exploration seul =).

    http://www.juliencorioland.net/Archi...exte-stateless

Discussions similaires

  1. [2.x] souci deleteAction avec le CRUD généré
    Par caema dans le forum Symfony
    Réponses: 1
    Dernier message: 23/04/2014, 16h42
  2. Réponses: 11
    Dernier message: 15/09/2008, 10h25
  3. #Erreur dans une requête avec une fonction personnalisée
    Par pguiheu dans le forum Requêtes et SQL.
    Réponses: 9
    Dernier message: 04/07/2006, 15h45

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