Publicité
+ Répondre à la discussion
Affichage des résultats 1 à 5 sur 5
  1. #1
    Membre du Club
    Développeur informatique
    Inscrit en
    septembre 2005
    Messages
    188
    Détails du profil
    Informations personnelles :
    Âge : 35

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : septembre 2005
    Messages : 188
    Points : 69
    Points
    69

    Par défaut Requête paramétrée avec deux paramètres

    Bonjour à tous,
    je souhaite faire une requête paramétrée avec deux paramètres du genre

    Code :
    " SELECT tbuser.ulogin, tbuser.upasswd, tbuser.uemployeur FROM public.tbuser WHERE tbuser.ulogin = param1 AND tbuser.upasswd = $param2
    Voilàa ce que j'ai fait, mais apparemment ce n'est pas bon:
    Code :
    " SELECT tbuser.ulogin, tbuser.upasswd, tbuser.uemployeur FROM public.tbuser WHERE tbuser.ulogin = $1 AND tbuser.upasswd = $2
    J'ai une erreur e syntaxe. Un coup de pousse sera apprécié. Merci d'avance.

  2. #2
    Expert Confirmé
    Profil pro
    Inscrit en
    octobre 2008
    Messages
    1 818
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : octobre 2008
    Messages : 1 818
    Points : 2 505
    Points
    2 505

    Par défaut

    Il manque le contexte pour répondre à cette question.

    Les requêtes se lancent dans un environnement comme un langage de programmation ou un programme comme psql ou pgadmin et la manière dont les paramètres doivent être passés dépend de cet environnement.

  3. #3
    Membre du Club
    Développeur informatique
    Inscrit en
    septembre 2005
    Messages
    188
    Détails du profil
    Informations personnelles :
    Âge : 35

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : septembre 2005
    Messages : 188
    Points : 69
    Points
    69

    Par défaut

    Le contexte c'est C# (VisualStudio).

  4. #4
    Membre du Club
    Développeur informatique
    Inscrit en
    septembre 2005
    Messages
    188
    Détails du profil
    Informations personnelles :
    Âge : 35

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : septembre 2005
    Messages : 188
    Points : 69
    Points
    69

    Par défaut

    En C# voilà le code
    Code :
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    OdbcCommand maCommande = new OdbcCommand("SELECT ulogin,upasswd,uemployeur FROM tbuser WHERE" + " ulogin=@param1 AND upasswd=@param2 ", maConnection);
                    //Paramètres 
                    maCommande.Parameters.ADD(new OdbcParameter("@param1", OdbcType.VarChar, 50));
                    maCommande.Parameters["@param1"].Value = txtparam1;
                    maCommande.Parameters.ADD(new OdbcParameter("@param2", OdbcType.VarChar, 50));
                    maCommande.Parameters["@param2"].Value = txtparam2;
                    //ON lit les infos avec le reader                
                    RETURN maCommande.ExecuteReader();
    Mais j'ai une erreur en retour.

    Je suis donc partie dans pgAdmin pour verifier la requête elle même
    "SELECT ulogin,upasswd,uemployeur FROM tbuser WHERE" + " ulogin=@param1 AND upasswd=@param2 "
    Mais j'ai une erreur donc besoin d'aide.

  5. #5
    Expert Confirmé
    Profil pro
    Inscrit en
    octobre 2008
    Messages
    1 818
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : octobre 2008
    Messages : 1 818
    Points : 2 505
    Points
    2 505

    Par défaut

    Sous pgAdmin il faudrait envoyer du SQL pur, c.a.d débarassé des syntaxes du genre @param qui sont destinées à l'API ODBC dans C#, et également des signes + ou double quotes de constructeurs de chaînes.

    En fait pgAdmin risque de ne pas aider beaucoup pour ton problème.

    En revanche le message d'erreur du code C# est censé aider.

Liens sociaux

Règles de messages

  • Vous ne pouvez pas créer de nouvelles discussions
  • Vous ne pouvez pas envoyer des réponses
  • Vous ne pouvez pas envoyer des pièces jointes
  • Vous ne pouvez pas modifier vos messages
  •