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 :

marqueur nommé et LIKE [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 marqueur nommé et LIKE
    Bonjour,
    j'ai apparemment un problème de syntaxe vu que $smt = $pdo->prepare('SELECT villes_texte FROM villes WHERE ville_nom LIKE %:ville_nom%'); me génère :
    Fatal error: Uncaught PDOException: SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '%?%' at line 1 in C:\projets\dvp\divers\dvp\search.php:41 Stack trace: #0 C:\projets\dvp\divers\dvp\search.php(41): PDO->prepare('SELECT villes_t...') #1 {main} thrown in C:\projets\dvp\divers\dvp\search.php on line 41
    alors que sans marqueur nommé, aucun problème : $smt = $pdo->prepare('SELECT villes_texte FROM villes WHERE ville_nom LIKE %'.$ville_nom:ville_nom.'%');. C'est quoi le bug SVP ?

  2. #2
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2022
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Suisse

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

    Informations forums :
    Inscription : Avril 2022
    Messages : 35
    Par défaut
    Bonjour
    Pas devant mon ordinateur pour tester, mais je pense que le problème vient de la %:ville_nom%. A cause des signes % juste avant les :, :ville_nom n'est pas pris comme un paramètre.

    Essaie avec ca :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $smt = $pdo->prepare('SELECT villes_texte FROM villes  WHERE ville_nom LIKE :ville_nom');
    $smt ->execute(array(':ville_nom' => '%' .$ville_nom. '%'));

  3. #3
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 329
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 329
    Billets dans le blog
    17
    Par défaut
    Je pense que la solution de Devas225 devrait fonctionner.

    Une autre solution si on souhaite laisser le max de SQL dans la requête :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sql = "... WHERE ville_nom LIKE CONCAT('%', :ville_nom, '%')";

  4. #4
    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
    Bonsoir,
    mon silence prolongé ne signifie pas un désintérêt pour vos solutions, mais un temps fou pour être en mesure de les prendre en compte...La solution de Devas225 fonctionne. J'ai un peu testé la solution de Séb.. Mais comme ça marchait pas tout de suite, j'ai abandonné...(d'abord, CONCAT ne prend que 2 arguments).

  5. #5
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 329
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 329
    Billets dans le blog
    17
    Par défaut
    d'abord, CONCAT ne prend que 2 arguments
    CONCAT() accepte de 1 à n arguments.

  6. #6
    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
    Désolé ; je savais pas. A noter qu'un seul argument, ça sert pas à grand chose...

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

Discussions similaires

  1. mysqli requête préparée et marqueurs nommés
    Par cc85 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 17/12/2021, 16h29
  2. Marqueur nommé ou interrogatif pour les requetes préparées ?
    Par sff dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 03/01/2019, 11h56
  3. Réponses: 2
    Dernier message: 30/09/2011, 12h00
  4. Instances nommées singleton-like
    Par kheironn dans le forum C#
    Réponses: 4
    Dernier message: 15/06/2009, 22h19
  5. [VB6] [ADO] Like sur base Access
    Par dlpxlid dans le forum VB 6 et antérieur
    Réponses: 9
    Dernier message: 24/01/2003, 11h03

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