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

Bases de données Delphi Discussion :

[SQLServer 2008] Message d'erreur "le type du paramètre n'est pas correct"


Sujet :

Bases de données Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Inscrit en
    Août 2007
    Messages
    55
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 55
    Par défaut [SQLServer 2008] Message d'erreur "le type du paramètre n'est pas correct"
    Bonsoir a tous, voilà je voudrais vérifier le mot de passe tapé par utilisateur, j'ai fait ceci mais j'ai un message d'erreur, le type du paramètre :mp n'est pas correcte. Quelqu'un pourrait m'aider ??

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    sqlstr:='SELECT name';
    sqlstr:=sqlstr+' FROM   sys.sql_logins ';
    sqlstr:=sqlstr+' WHERE pwdcompare(:mp, password_hash)=1';
    qverifmp.sql.clear
    qverifmp.sql.add(sqlstr);
    qverifmp.Parameters[0].Value:=Password.text;
    qverifmp.OPEN;

  2. #2
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 635
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 635
    Billets dans le blog
    65
    Par défaut
    Bonjour,

    Il faudrait déjà indiquer de quels composants il s'agit ?
    ensuite faite plus lisible comme code

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    qverifmp.sql.clear
    qverifmp.sql.add('SELECT name FROM sys.sql_logins');
    qverifmp.sql.add('WHERE pwdcompare(:mp, password_hash)=1');
     // le passage de paramètre dépendra beaucoup du composant utilisé, il faut peut-être selon le cas définir le type de paramètre
    // si ADO
    qverifmp.Parameters.parambyname('mp').datatype:=ftstring; 
    qverifmp.Parameters.parambyname('mp').Value:=Password.txt;
    
    
    qverifmp.OPEN;
    il faut aussi avoir une autorisation d'accès CONTROL SERVER

  3. #3
    Membre actif
    Inscrit en
    Août 2007
    Messages
    55
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 55
    Par défaut Sqlserver 2008/ Delphi message d'erreur
    Bonjour, oui , j'utilise un Tadoquery. Merci

  4. #4
    Membre actif
    Inscrit en
    Août 2007
    Messages
    55
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 55
    Par défaut Sqlserver 2008/ Delphi message d'erreur
    Rebonjour, le composant c'est Tadoquery, le paramètre ":mp" est de type string, et c'est là que le message d'erreur se signal, merci beaucoup pour votre aide

  5. #5
    Membre éclairé

    Homme Profil pro
    Mathématicien
    Inscrit en
    Juin 2016
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Mathématicien

    Informations forums :
    Inscription : Juin 2016
    Messages : 32
    Par défaut
    Le paramètre est de type string donc il faut peut-être utiliser un QuotedStr ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    qverifmp.Parameters[0].Value:=QuotedStr(Password.text);

  6. #6
    Expert éminent
    Avatar de Paul TOTH
    Homme Profil pro
    Freelance
    Inscrit en
    Novembre 2002
    Messages
    8 964
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Novembre 2002
    Messages : 8 964
    Par défaut
    Citation Envoyé par MaxiDonkey Voir le message
    Le paramètre est de type string donc il faut peut-être utiliser un QuotedStr ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    qverifmp.Parameters[0].Value:=QuotedStr(Password.text);
    non, c'est l'objet des paramètres que de ne pas encoder les valeurs

    QuotedStr ça serait pour écrire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
      qverifmp.sql.Text := 'SELECT name FROM sys.sql_logins WHERE pwdcompare('  + QuotedStr(Password.text) + ', password_hash)=1');
    Developpez.com: Mes articles, forum FlashPascal
    Entreprise: Execute SARL
    Le Store Excute Store

Discussions similaires

  1. Réponses: 16
    Dernier message: 22/02/2010, 17h18
  2. Réponses: 2
    Dernier message: 03/01/2010, 22h05
  3. Migration vers VS 2008 : message d'erreur à l'éxécution
    Par troubleshooting dans le forum Général Dotnet
    Réponses: 0
    Dernier message: 29/07/2008, 13h59
  4. Message d'erreur de type de variable
    Par maxmarie dans le forum ASP.NET
    Réponses: 2
    Dernier message: 01/08/2007, 17h15
  5. [VB6]sqlserver 2000 message d'erreur
    Par Abydos Business Group dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 24/03/2006, 19h33

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