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 :

Erreur 'SQLSTATE[HY093]' lors d'opérations sur $bdd


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2018
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 76
    Localisation : France, Cher (Centre)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Janvier 2018
    Messages : 42
    Par défaut Erreur 'SQLSTATE[HY093]' lors d'opérations sur $bdd
    J'ai écrit un script destiné à permettre de transférer les données de la table 'equipements_encours' vers la table 'historiqueequipements' (voir l'extrait ci-dessous)

    A première vue tout me semble OK: toutes les données correspondent (dans 'prepare' aussi bien que dans 'array') mais lors du lancement du script, je reçois systématiquement le message d'erreur suivant:

    ( ! ) Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[HY093]:'Invalid parameter number: number of bound variables does not match number of tokens' in C:\wamp\www\EASY.... on line 270

    NB: la ligne 270 dans mon script est la ligne 31 dans l'extrait ci-dessous

    Code : 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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
     
    //Récupération des données de 'equipements_encours':
     
    $req = $bdd->prepare('SELECT * FROM equipements_encours WHERE RefGesnavAeronef=:RefGesnavAeronef') or die(print_r($bdd->errorInfo()));
     
    		$req->execute(array(
    		'RefGesnavAeronef'=> $_SESSION['RefGesnavAeronef']		
    		));
     
    		while($donnees = $req->fetch())
    		{
    		$TypeEquipement=$donnees['TypeEquipement'];
    		$FabricantEquipement=$donnees['FabricantEquipement'];
    		$ModeleEquipement=$donnees['ModeleEquipement'];
    		$NumeroSerieEquipement=$donnees['NumeroSerieEquipement'];
    		$InventairePesee=$donnees['InventairePesee'];
     
    //Insertion des données de 'equipements_encours' dans 'historiqueequipements':	
     
    		$req1 = $bdd->prepare('INSERT INTO historiqueequipements(RefGesnavAeronef,intituleOperation,dateCloture,TypeEquipement,FabricantEquipement,ModeleEquipement,NumeroSerieEquipement,InventairePesee) VALUES(:RefGesnavAeronef,:intituleOperation,:dateCloture,:TypeEquipement,:FabricantEquipement,:ModeleEquipement,;NumeroSerieEquipement,:InventairePesee)');
     
    		$req1->execute(array (
    		'RefGesnavAeronef'=>  $_SESSION['RefGesnavAeronef'],	
    		'intituleOperation'=>$_SESSION['intituleOperation'],
    		'dateCloture'=>$_SESSION['dateCloture'],	
    		'TypeEquipement'=>$TypeEquipement,
    		'FabricantEquipement'=>$FabricantEquipement,
    		'ModeleEquipement'=>$ModeleEquipement,
    		'NumeroSerieEquipement'=>$NumeroSerieEquipement,
    		'InventairePesee'=>$InventairePesee	
    		));
    		}
    Quelqu'un voit-il l'erreur?

    Merci

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    tu as un ; au lieu de :

    Sinon beaucoup plus court :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $req1 = $bdd->exec('INSERT INTO historiqueequipements(RefGesnavAeronef,intituleOperation,dateCloture,TypeEquipement,FabricantEquipement,ModeleEquipement,NumeroSerieEquipement,InventairePesee)
    SELECT (:RefGesnavAeronef,:intituleOperation,:dateCloture,TypeEquipement,FabricantEquipement,ModeleEquipement,NumeroSerieEquipement,InventairePesee
    FROM  equipements_encours WHERE RefGesnavAeronef=:RefGesnavAeronef_where)');
    $req->execute(array(
    		':RefGesnavAeronef'=> $_SESSION['RefGesnavAeronef'],
    		':intituleOperation'=>$_SESSION['intituleOperation'],
    		':dateCloture'=>$_SESSION['dateCloture'],
    		':RefGesnavAeronef_where'=>  $_SESSION['RefGesnavAeronef']
    		));
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2018
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 76
    Localisation : France, Cher (Centre)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Janvier 2018
    Messages : 42
    Par défaut [PHP 5.5] Erreur 'SQLSTATE[HY093]' lors d'opérations sur $bdd
    Merci: j'avais passé des heures sans parvenir à détecter ce;. Bonne leçon pour l'avenir. Une question seulement dans le code que tu proposes, je pense que le deuxième $req $req->execute est plutôt: $req1->execute, n'est-ce-pas?
    Merci en tous cas

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    oui
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

Discussions similaires

  1. Réponses: 2
    Dernier message: 30/05/2015, 19h47
  2. Erreur lors des opérations sur les dates
    Par Alexandre le Grand dans le forum Entity Framework
    Réponses: 14
    Dernier message: 07/08/2014, 02h27
  3. [WD16] Optimiser les opérations sur BDD lourde
    Par JustineJ dans le forum WinDev
    Réponses: 16
    Dernier message: 04/01/2012, 17h34
  4. opération sur bdd fireBird
    Par tarek_ep dans le forum Bases de données
    Réponses: 2
    Dernier message: 04/02/2009, 20h24
  5. Erreur non bloquante lors du TemplateBinding sur RectangleGeometry
    Par olsimare dans le forum Windows Presentation Foundation
    Réponses: 1
    Dernier message: 20/03/2008, 01h17

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