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

SQL Procédural MySQL Discussion :

Problème trigger BEFORE UPDATE


Sujet :

SQL Procédural MySQL

  1. #1
    Expert éminent
    Avatar de berceker united
    Profil pro
    SQL
    Inscrit en
    Février 2005
    Messages
    3 494
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : SQL
    Secteur : Finance

    Informations forums :
    Inscription : Février 2005
    Messages : 3 494
    Points : 6 062
    Points
    6 062
    Par défaut Problème trigger BEFORE UPDATE
    Bonjour.
    J'essais de créer un trigger qui n'autorise qu'un seul enregistrement ayant le champs "true". En faite, c'est la langue par defaut j'ai pensé au trigger dans le cas ou il y a malin qui joue dans la table directement.
    Voici le trigger.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    CREATE TRIGGER OneDefautInLangueFordefaut 
      BEFORE UPDATE ON langue 
      FOR EACH ROW  
      BEGIN  
        IF new.defaut =1 THEN  
          UPDATE langue SET defaut =0 WHERE idlangue <> old.idlangue;
          SET defaut = old.defaut;
        END IF
      END
    Mais apparement il aime pas le UPDATE et je nevois pas qu'il pourrait le gener.
    Aurais-je raté quelque chose ?

  2. #2
    Membre émérite Avatar de Maximil ian
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    2 622
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 2 622
    Points : 2 973
    Points
    2 973
    Par défaut
    Qu'est-ce qui ne fonctionne pas exactement ? Ca serait pas SET new.defaut = old.defaut ?

    PS : merci de mettre un titre explicite à tes posts

  3. #3
    Expert éminent
    Avatar de berceker united
    Profil pro
    SQL
    Inscrit en
    Février 2005
    Messages
    3 494
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : SQL
    Secteur : Finance

    Informations forums :
    Inscription : Février 2005
    Messages : 3 494
    Points : 6 062
    Points
    6 062
    Par défaut
    Extrait de l'autre post
    ... l'utilisateur peut décider quelle sera la langue par défaut parmis une liste qu'il aura renseigner. Très logiquement, il ne peut qu'avoir qu'une langue par défaut. Si le renseignement de la langue par défaut n'existe pas pour x raison c'est la table parametre qui prend le relais. C'est empecher qu'il puisse y avoir plus d'une enregistrement ayant "true" sur défaut.
    Voila pourquoi je voulais faire un udpate de tout les enregistements defaut=0 (tynint(1)) puis faire un update sur l'enregistrement en question à 1.
    Exemple :

    idlangue | langue | defaut
    1 | Français | x
    2 | Englais |
    3 | Allemand |

    UPDATE langue SET defaut = 1 WHERE idlangue = 3

    idlangue | langue | defaut
    1 | Français |
    2 | Englais |
    3 | Allemand | x


    Désolé pour le titre

  4. #4
    Membre émérite Avatar de Maximil ian
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    2 622
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 2 622
    Points : 2 973
    Points
    2 973
    Par défaut
    Heu oui mais ça répond pas vraiment à la question... tu as essayé SET new.defaut au lieu de SET defaut ?

  5. #5
    Expert éminent
    Avatar de berceker united
    Profil pro
    SQL
    Inscrit en
    Février 2005
    Messages
    3 494
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : SQL
    Secteur : Finance

    Informations forums :
    Inscription : Février 2005
    Messages : 3 494
    Points : 6 062
    Points
    6 062
    Par défaut
    Voici la nouvelle version
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    DROP TRIGGER OneDefautInLangueFordefaut ;
    CREATE TRIGGER OneDefautInLangueFordefaut 
      BEFORE UPDATE ON langue 
      FOR EACH ROW  
          UPDATE langue SET defauts=0;
          SET new.defauts= old.defauts;
    J'ai l'erreur suivant : #1193 - Unknown system variable 'defauts' ceci à la ligne SET new.defauts= old.defaut
    Au départ je pensais que c'étais un mot reservé mais apparément non le mot réservé c'est default en cas ou j'ai placé un "s".

  6. #6
    Membre éprouvé
    Avatar de Biglo
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    537
    Détails du profil
    Informations personnelles :
    Localisation : France, Moselle (Lorraine)

    Informations forums :
    Inscription : Juillet 2002
    Messages : 537
    Points : 984
    Points
    984
    Par défaut
    C'est un problème de délimiteur. Ton trigger s'arrête au UPDATE là et le SET devient une instruction à part.

    De plus, il te faut un BEGIN ... END si tu as plusieurs instructions dans le trigger.

    Et enfin, il me semble que c'est interdit de modifier la table concernée par le trigger.

  7. #7
    Expert éminent
    Avatar de berceker united
    Profil pro
    SQL
    Inscrit en
    Février 2005
    Messages
    3 494
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : SQL
    Secteur : Finance

    Informations forums :
    Inscription : Février 2005
    Messages : 3 494
    Points : 6 062
    Points
    6 062
    Par défaut
    Merci pour l'information. J'ai des problèmes avec le delimiter mais je pense que c'est dù a phpmyadmin. En ligne de commande je ne sais pas choisir ma base de données pour tester

  8. #8
    Membre éprouvé
    Avatar de Biglo
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    537
    Détails du profil
    Informations personnelles :
    Localisation : France, Moselle (Lorraine)

    Informations forums :
    Inscription : Juillet 2002
    Messages : 537
    Points : 984
    Points
    984
    Par défaut
    Avec le client console, tu choisis ta base par défaut avec USE :

    C'est l'équivalent de mysql_select_db().

    Sinon, si tu préfères (ce dont je doute), tu peux préfixer ton trigger et tes tables par le nom de la base.

  9. #9
    Expert éminent
    Avatar de berceker united
    Profil pro
    SQL
    Inscrit en
    Février 2005
    Messages
    3 494
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : SQL
    Secteur : Finance

    Informations forums :
    Inscription : Février 2005
    Messages : 3 494
    Points : 6 062
    Points
    6 062
    Par défaut
    Citation Envoyé par Biglo
    Avec le client console, tu choisis ta base par défaut avec USE :

    C'est l'équivalent de mysql_select_db().

    Sinon, si tu préfères (ce dont je doute), tu peux préfixer ton trigger et tes tables par le nom de la base.
    Merci pour la commande.

    s'te honte quand même de demander cela .

    Bref, je teste ça des ce soir. Si ça ne fonctionne pas je gère cela par code ce qui est plus simple mais bon tant pis s'il y a quelqu'un qui tente de jouer dans la base de données.

    Merci pour vos intervention.

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

Discussions similaires

  1. [MySql5.5] Trigger before update Oo
    Par Xploit dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 08/09/2011, 15h41
  2. Trigger before update erreur ORA-04091
    Par cyril dans le forum PL/SQL
    Réponses: 2
    Dernier message: 17/09/2010, 11h35
  3. Trigger Before Update
    Par sat83 dans le forum Débuter
    Réponses: 1
    Dernier message: 14/04/2009, 10h52
  4. Syntaxe Trigger before update
    Par dcabe dans le forum PL/SQL
    Réponses: 8
    Dernier message: 21/07/2008, 09h53
  5. Trigger before update
    Par Virtuosity dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 27/05/2008, 10h26

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