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 :

Update Mysql ne se fait pas


Sujet :

PHP & Base de données

  1. #1
    Membre du Club
    Homme Profil pro
    Cobol sur Mainframe et Unix AIX
    Inscrit en
    Mars 2012
    Messages
    196
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Cobol sur Mainframe et Unix AIX

    Informations forums :
    Inscription : Mars 2012
    Messages : 196
    Points : 69
    Points
    69
    Par défaut Update Mysql ne se fait pas
    Bonjour,

    Voici mon code pour ma classe qui accède à ma table :
    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
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
     
    <?php
    	class tarifs
    	{
    		private $insert;
    		private $update;
    		private $SelectOneMontant;
    		private $selectAll;
     
    		public function __construct($db)
    		{
    			$this-> insert = $db->prepare("insert into scf_grille_tarif (Type_Tarif, Montant) 
    												                values (:Type_Tarif, :Montant)");
    			$this-> selectAll = $db->prepare("select * from scf_grille_tarif where idSaison = :idSaison");
    			$this-> SelectOneMontant = $db->prepare("select Montant from scf_grille_tarif where Type_Tarif = :Type_Tarif");
    			$this-> update = $db->prepare("update scf_grille_tarif set Montant = :Montant where Type_Tarif = :Type_Tarif");
    		}
     
    		public function insert($Type_Tarif, $Montant)
    		{
    			$this -> insert -> execute(array(':Type_Tarif' => $Type_Tarif, 
    											 ':Montant' => $Montant));
    			return $this->insert->rowCount();
    		}
     
    		public function selectAll()
    		{
    			$this -> selectAll -> execute();
    			return $this->selectAll->fetchAll();
    		}
     
    		public function SelectOneMontant($Type_Tarif)
    		{
    			$this -> SelectOneMontant -> execute(array(':Type_Tarif' => $Type_Tarif));
    			return $this->SelectOneMontant->fetch();
    		}
     
    		public function update($Type_Tarif, $Montant)
    		{
    			echo " (dans class_Montant. Type_Tarif : $Type_Tarif - Montant : $Montant)";
    			$this -> update -> execute(array(':Montant' => $Montant, ':Type_Tarif' => $Type_Tarif));
    			return $this->update->rowCount();
    		}
    	}
    ?>
    Lorque j'appelle ma fonction update, la fonction renvoie 0 row.
    Voici comment je l'appelle :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $nb = $Tarifs->update($cle, $valeur);
    L'insert se fait sans pb.

    Voici les traces :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Poste : 1 - UnTarif : 125.00 - MAJ du poste 1 avec la valeur 125.00 (dans class_Montant. Type_Tarif : 1 - Montant : 125.00)
    Ca a échoué car la variable nb=0!
    Arrêt du traitement
    Savez-vous pourquoi ?

    Merci pour votre aide.

    Eddy

  2. #2
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Le fait que rowNum renvoie 0 veut dire qu'aucune ligne n'a été mise à jour, mais a priori, la requête s'exécute sans problème.
    Vérifie donc les données dans ta base avant l'exécution. Tu peux également ajouter un appel à debugDumpParams pour voir ce qu'il se passe réellement :
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

Discussions similaires

  1. [PDO] UPDATE qui ne se fait pas
    Par laurentSc dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 06/02/2015, 23h57
  2. [MySQL] update pdo ne se fait pas
    Par serna dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 12/03/2013, 22h38
  3. [Ajax.NET]UpdataPanel.Update() qui ne se fait pas
    Par rad_hass dans le forum ASP.NET
    Réponses: 4
    Dernier message: 12/03/2009, 09h27
  4. [MySQL] UPDATE qui ne se fait pas
    Par VoteForMe dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 17/09/2008, 13h42
  5. [MySQL] MySQL Update qui ne se fait pas
    Par philippef dans le forum PHP & Base de données
    Réponses: 13
    Dernier message: 10/07/2008, 17h30

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