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

Requêtes PostgreSQL Discussion :

Requête paramétrée avec deux paramètres


Sujet :

Requêtes PostgreSQL

  1. #1
    Membre averti
    Homme Profil pro
    Ingénieur Développement Logiciel
    Inscrit en
    Septembre 2005
    Messages
    285
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Ingénieur Développement Logiciel
    Secteur : Service public

    Informations forums :
    Inscription : Septembre 2005
    Messages : 285
    Points : 421
    Points
    421
    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 : Sélectionner tout - Visualiser dans une fenêtre à part
    " 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 : Sélectionner tout - Visualiser dans une fenêtre à part
    " 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
    Membre émérite
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    1 874
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 874
    Points : 2 890
    Points
    2 890
    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 averti
    Homme Profil pro
    Ingénieur Développement Logiciel
    Inscrit en
    Septembre 2005
    Messages
    285
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Ingénieur Développement Logiciel
    Secteur : Service public

    Informations forums :
    Inscription : Septembre 2005
    Messages : 285
    Points : 421
    Points
    421
    Par défaut
    Le contexte c'est C# (VisualStudio).

  4. #4
    Membre averti
    Homme Profil pro
    Ingénieur Développement Logiciel
    Inscrit en
    Septembre 2005
    Messages
    285
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Ingénieur Développement Logiciel
    Secteur : Service public

    Informations forums :
    Inscription : Septembre 2005
    Messages : 285
    Points : 421
    Points
    421
    Par défaut
    En C# voilà le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
    Membre émérite
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    1 874
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 874
    Points : 2 890
    Points
    2 890
    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.

Discussions similaires

  1. Requête paramétrée avec deux parametres l'id du getSelect
    Par waritigui dans le forum MkFramework
    Réponses: 4
    Dernier message: 12/06/2015, 21h15
  2. [AC-2003] Requête paramétrée avec deux listes déroulantes.
    Par hadrimo dans le forum Access
    Réponses: 3
    Dernier message: 17/10/2014, 22h58
  3. Problème de requêtes avec deux paramètres
    Par Ahlina dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 01/04/2013, 00h21
  4. Réponses: 1
    Dernier message: 07/04/2010, 09h56
  5. [AC-2007] requête mise à jour avec deux paramètres
    Par gerarddurand dans le forum Requêtes et SQL.
    Réponses: 8
    Dernier message: 15/01/2010, 12h07

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