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 :

Trigger en php/pdo [PDO]


Sujet :

PHP & Base de données

  1. #1
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2015
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2015
    Messages : 33
    Points : 48
    Points
    48
    Par défaut Trigger en php/pdo
    Bonjour,

    Je ne suis pas certain que ce soit le bon forum, je m'excuse d'avance si je me suis trompé.
    Je rencontre un petit "problème", auparavant j'avais codé en php une insertion de données avant suppression (insertion dans une table "archive") et m'étant un peu renseigné sur d'autres possibilités, j'ai remarqué qu'il était peut-être préférable de faire cela via trigger ?
    Néanmoins n'ayant jamais fait de trigger je coince un peu avec ceci :

    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
     
    require_once('../modele/bdd.php');
     
     
    	if(isset($_POST['del'])) {
     
    		$reserv = htmlspecialchars($_POST['del']);
    		$archivage = $db->prepare("SELECT * FROM reservation WHERE id_reservation = :id");
    		$archivage->execute(array(':id'=>$reserv));
    		$resultat = $archivage->fetch();
     
    		$trigger = $db->prepare('CREATE TRIGGER tr_archivage 
                    AFTER DELETE 
    		ON reservation 
    	        FOR EACH ROW
     
    		DECLARE
    			id = '.$reserv.';
     
    		BEGIN 
     
    			INSERT INTO archive (id_reservation, id_adherent, date)
    			VALUES(:id_reservation, :id_adherent, :date)			
     
    		END;');				
    $trigger->execute(array(
    			':id_reservation'=>$resultat['id_reservation'],
    			':id_adherent'=>$resultat['id_adherent'],
    			':date'=>$resultat['date']
    			));
    $result = $trigger->fetch();
    Désolé pour l'indentation bizarre. J'avais jamais fait de trigger auparavant, il est possible que ce soit vraiment horrible à voir. :/
    En résumé : Je souhaiterais insérer dans une table archive les données supprimées de ma table reservation grâce à ce trigger

    Je ne sais pas si le $result = $trigger->fetch(); est nécessaire, il suffit simplement de l'executer non?

    Voici l'erreur obtenue :

    Warning: PDOStatement::execute(): 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 'DECLARE id = 218; BEGIN INSERT INTO archive (id_reservatio' at line 6 in C:\wamp\www\SuapsGolf\modele\suppr.php on line 35
    Merci d'avance ^^

  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
    Points : 44 155
    Points
    44 155
    Par défaut
    Tu fais complétement fausse route.
    L'interêt d'un trigger est que Mysql execute automatiquement des actions, sans intervention de PHP donc.
    Si tu devais faire un trigger avec PHP à chaque suppression, quel serait l’intérêt par rapport à la requête que tu avais avant ?

    Donc directement dans PHPmyadmin :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    CREATE TRIGGER tr_archivage 
    AFTER DELETE ON reservation 
    FOR EACH ROW
    INSERT INTO archive
       ( id_reservation, id_adherent, `date`)
       VALUES ( OLD.id_reservation, OLD.id_adherent, OLD.`date`)
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2015
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2015
    Messages : 33
    Points : 48
    Points
    48
    Par défaut
    Wow j'ai honte. Merci en tout cas de m'avoir éclairé Sabotage.

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

Discussions similaires

  1. [PDO] PHP/PDO ne marche pas en ligne de commande
    Par ofostier dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 03/10/2009, 11h29
  2. Trigger ou php?
    Par punksociety2 dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 16/04/2009, 09h07
  3. [MySQL] Création de trigger depuis PHP
    Par Shiva dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 12/01/2007, 13h16
  4. [PHP5.2][MySQL5.0.27] Creation de triggers depuis PHP
    Par frochard dans le forum SQL Procédural
    Réponses: 4
    Dernier message: 05/12/2006, 10h16
  5. [SQL] [php] PDO - fonction BindParam
    Par fadeninev dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 23/06/2006, 15h36

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