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 :

Question requête SQL [Débutant]


Sujet :

ASP.NET MVC

  1. #1
    Membre confirmé Avatar de Caranille
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2013
    Messages
    117
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2013
    Messages : 117
    Par défaut Question requête SQL
    Bonjour tous le monde,

    Voilà je suis coincé sur une simple requête SQL, pour vous résumer le programme il y a une page ou l'internaute créer son compte, son pseudo est ensuite gardé en session et l'internaute est invité à créer son personnage (avatar) qui aura une liaison avec la clé primaire du compte.

    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
    [HttpPost]
            [ValidateAntiForgeryToken]
            public IActionResult AddAccount(Accounts accounts)
            {
                accounts.Access = 1;
                accounts.LastConnection = DateTime.Now.ToString();
                accounts.LastIP = Request.HttpContext.Connection.RemoteIpAddress.ToString();
                accounts.Status = 0;
                accounts.Reason = "None";
     
                if (ModelState.IsValid)
                {
                    HttpContext.Session.SetString("Pseudo", accounts.Pseudo);
                    _context.Accounts.Add(accounts);
                    _context.SaveChanges();
                    return RedirectToAction("Character");
                }
                return View("Index");
            }
    Donc comme vous le voyez le compte est bien crée et ajouté dans la BDD, je garde donc le pseudo en session pour pouvoir faire par la suite une requête SQL pour connaitre l'ID qui a été attribué à ce pseudo dans la BDD

    Voici maintenant le code de quand l'internaute à rempli le formulaire de création du personnage:
    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
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    [HttpPost]
            [ValidateAntiForgeryToken]
            public IActionResult AddCharacter(Characters character)
            {
                var Pseudo = HttpContext.Session.GetString("Pseudo");
                var AccountID = _context.Accounts
                .FromSql("SELECT * FROM Accounts WHERE Account.Pseudo =", Pseudo)
                .ToList();
                character.AccountID = Convert.ToInt32(AccountID.);
                character.Level = 1;
                character.HPCurrent = 120;
                character.HPLevel = 120;
                character.HPSP = 0;
                character.HPEquipment = 0;
                character.HPParchment = 0;
                character.HPTotal = 120;
                character.MPCurrent = 10;
                character.MPLevel = 10;
                character.MPSP = 0;
                character.MPEquipment = 0;
                character.MPParchment = 0;
                character.MPTotal = 10;
                character.StrengthLevel = 10;
                character.StrengthSP = 0;
                character.StrengthEquipment = 0;
                character.StrengthParchment = 0;
                character.StrengthTotal = 10;
                character.MagicLevel = 10;
                character.MagicSP = 0;
                character.MagicEquipment = 0;
                character.MagicParchment = 0;
                character.MagicTotal = 10;
                character.AgilityLevel = 10;
                character.AgilitySP = 0;
                character.AgilityEquipment = 0;
                character.AgilityParchment = 0;
                character.AgilityTotal = 10;
                character.DefenseLevel = 10;
                character.DefenseSP = 0;
                character.DefenseEquipment = 0;
                character.DefenseParchment = 0;
                character.DefenseTotal = 10;
                character.DefenseMagicLevel = 10;
                character.DefenseMagicSP = 0;
                character.DefenseMagicEquipment = 0;
                character.DefenseMagicParchment = 0;
                character.DefenseMagicTotal = 100;
                character.WisdomLevel = 0;
                character.WisdomSP = 0;
                character.WisdomEquipment = 0;
                character.WisdomParchment = 0;
                character.WisdomTotal = 0;
                character.Experience = 0;
                character.SkillPoint = 0;
                character.Gold = 0;
                character.TownID = 0;
                character.Chapter = 0;
     
                if (ModelState.IsValid)
                {
                    _context.Characters.Add(character);
                    _context.SaveChanges();
                    return RedirectToAction("Index");
                }
                return View("Index");
            }
    Sauf que je ne sais pas comment récupérer le résultat, je sens bien qu'entre PHP et l'ASP.NET il y a un fossé :p

    Merci de votre aide

    Cordialement,

  2. #2
    Rédacteur
    Avatar de Hinault Romaric
    Homme Profil pro
    Consultant
    Inscrit en
    Janvier 2007
    Messages
    4 570
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

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

    Informations forums :
    Inscription : Janvier 2007
    Messages : 4 570
    Billets dans le blog
    121
    Par défaut
    Bonjour,

    Même si Entity Framework supporte le SQL natif, le meilleur moyen de manipuler les données est l'utilisation de Linq to Entities. Puisque tu y es, je te conseille de t'y mettre. Tu trouveras de nombreux tutoriels sur le sujet sur Internet.

    En ce qui concerne ton problème, tu aurais simplement pu procéder comme suit avec Linq to Entities :

    Code c# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    var account = _context.Accounts.SingleOrDefault(a => a.Pseudo == Pseudo);
    character.AccountID = account.AccountID;

    Prends la peine de lire les bases sur Entity Framework. Ca t’évitera de cogner la tête au mur pour des choses assez simples.
    Vous souhaitez participer aux rubriques .NET ? Contactez-moi

    Si déboguer est l’art de corriger les bugs, alors programmer est l’art d’en faire
    Mon blog, Mes articles, Me suivre sur Twitter
    En posant correctement votre problème, on trouve la moitié de la solution

  3. #3
    Membre confirmé Avatar de Caranille
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2013
    Messages
    117
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2013
    Messages : 117
    Par défaut
    Bonsoir,

    Merci beaucoup de ton aide cela fonctionne ^^

    J'admet en regardant d'un peu plus prêt l'Entity Framework je me rends compte que les requêtes SQL "Pure" ne sont là que pour des cas très particulier mais pour des besoins classiques l'EF peut faire tout le travail.

    Merci de ton conseil que je vais appliquer

    Cordialement,

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

Discussions similaires

  1. requête SQL : question
    Par Australia dans le forum Requêtes
    Réponses: 11
    Dernier message: 31/05/2010, 15h36
  2. [MySQL] [Requête SQL] Question Fonctions PHP
    Par Paul75 dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 22/09/2008, 09h05
  3. [SQL] Question sur requête SQL
    Par Cheeper dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 27/06/2007, 17h56
  4. Requte Sql Avancée, question ... ? Estce possible ?
    Par plex dans le forum Administration
    Réponses: 8
    Dernier message: 14/12/2005, 15h13

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