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

PHP & Base de données Discussion :

requête correcte pour MysqlWorkbench mais pas pour PDO [PDO]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut requête correcte pour MysqlWorkbench mais pas pour PDO
    Bonsoir,

    voici mon code PHP :

    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
                 $sql = <<<sql
    insert into search (user_id, ville_id)
    values (  (select user_id  from user  where user_login=:user_nom)
     , (select ville_id from villes where ville_nom LIKE :ville_nom)
    ) 
    sql;
                $smt = $pdo->prepare($sql);
                $res = $smt ->execute(array(':user_login' => $user_nom,':ville_nom' => "%".$ville_nom."%"));
    et le message d'erreur :
    Fatal error: Uncaught PDOException: SQLSTATE[HY093]: Invalid parameter number in C:\projets\dvp\copie\search.php:65 Stack trace: #0 C:\projets\dvp\copie\search.php(65): PDOStatement->execute(Array) #1 {main} thrown in C:\projets\dvp\copie\search.php on line 65
    Pourtant si je teste la même requête avec un jeu de données (n'importe lequel) avec MysqlWorkbench, l'insertion est bien faite.
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    insert into search (user_id, ville_id)
    values (  (select user_id  from user  where user_login='laurent')
            , (select ville_id from villes where ville_nom LIKE '%mad%'))
    Voici le DDL des tables search, user et villes :
    Code sql : 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
    CREATE TABLE `search` (
      `user_id` varchar(30) NOT NULL DEFAULT 'null',
      `ville_id` varchar(11) NOT NULL DEFAULT 'null'
    ) ENGINE=MyISAM DEFAULT CHARSET=latin1;
     
    CREATE TABLE `user` (
      `user_id` tinyint NOT NULL AUTO_INCREMENT,
      `user_login` varchar(20) NOT NULL,
      `user_password` varchar(34) NOT NULL,
      PRIMARY KEY (`user_id`)
    ) ENGINE=MyISAM AUTO_INCREMENT=19 DEFAULT CHARSET=latin1;
     
    CREATE TABLE `villes` (
      `ville_ID` int NOT NULL AUTO_INCREMENT,
      `ville_nom` varchar(15) NOT NULL,
      `villes_texte` text NOT NULL,
      PRIMARY KEY (`ville_ID`)
    ) ENGINE=MyISAM AUTO_INCREMENT=6 DEFAULT CHARSET=latin1;

    Pourquoi SVP ?

  2. #2
    Membre émérite Avatar de Willy_k
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2011
    Messages
    541
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juin 2011
    Messages : 541
    Par défaut
    Bonsoir,

    En même temps user_login est différent de user_nom au niveau des marqueurs. Le test dans workbench est différent de celui effectué avec PHP.

  3. #3
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut
    Merci, ça va de soi, mais j'avais tellement le nez dans le guidon que je ne le voyais pas...

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

Discussions similaires

  1. Ma requête fonctionne dans phpMyAdmin mais pas avec PDO
    Par moimp dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 26/08/2020, 00h00
  2. [Div]Positionnement correct sous IE7 mais pas sous Firefox
    Par Janitrix dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 03/05/2007, 10h16
  3. erreur de requête SQL avec ASP mais pas dans Access
    Par csszzen dans le forum Langage SQL
    Réponses: 6
    Dernier message: 16/03/2007, 09h07
  4. Correctement sous IE mais pas sous firefox
    Par cyrille777 dans le forum Mise en page CSS
    Réponses: 17
    Dernier message: 01/03/2007, 22h41
  5. Requête OK sur easyphp mais pas sur mon hébergeur
    Par Pgs dans le forum Requêtes
    Réponses: 3
    Dernier message: 30/10/2006, 19h09

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