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 :

[Trigger] Erreur 1136 lors d'une insertion


Sujet :

SQL Procédural MySQL

  1. #1
    Membre à l'essai
    Inscrit en
    Novembre 2004
    Messages
    17
    Détails du profil
    Informations forums :
    Inscription : Novembre 2004
    Messages : 17
    Points : 12
    Points
    12
    Par défaut [Trigger] Erreur 1136 lors d'une insertion
    Bonjour,
    je suis en train de faire un petit systeme de gestion de DVD.
    Je souhaiterai utiliser un trigger qui, lors de l'insertion d'un nouveau DVD va inserer un nouvelle ligne dans une table stock et inserer une nouvelle ligne dans une table realise (cette table associe un ID de realisateur, situe dans une autre table et l'ID d'un DVD)
    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
     
    mysql> desc dvd;desc realise;desc stock;
    +-----------+-------------+------+-----+------------+----------------+
    | Field     | Type        | Null | Key | Default    | Extra          |
    +-----------+-------------+------+-----+------------+----------------+
    | id        | int(11)     | NO   | PRI | NULL       | auto_increment |
    | titre     | varchar(30) | NO   |     |            |                |
    | annee     | date        | NO   |     | 0000-00-00 |                |
    | pays      | char(2)     | NO   | PRI |            |                |
    | anneeFilm | date        | NO   |     | 0000-00-00 |                |
    +-----------+-------------+------+-----+------------+----------------+
    5 rows in set (0.00 sec)
     
    +---------+---------+------+-----+---------+-------+
    | Field   | Type    | Null | Key | Default | Extra |
    +---------+---------+------+-----+---------+-------+
    | artiste | int(11) | NO   | PRI | 0       |       |
    | dvd     | int(11) | NO   | PRI | 0       |       |
    +---------+---------+------+-----+---------+-------+
    2 rows in set (0.00 sec)
     
    +----------+---------+------+-----+---------+-------+
    | Field    | Type    | Null | Key | Default | Extra |
    +----------+---------+------+-----+---------+-------+
    | dvd      | int(11) | NO   | PRI | 0       |       |
    | quantite | int(11) | NO   |     | 0       |       |
    | reste    | int(11) | NO   |     | 0       |       |
    +----------+---------+------+-----+---------+-------+
    3 rows in set (0.03 sec)
     
     
    mysql> delimiter ¦
    mysql> create trigger aj_stock_realise after insert on dvd
        -> FOR EACH ROW BEGIN
        -> insert into stock values (NEW.id), (1), (1);
        -> insert into realise values (0), (NEW.id);
        -> end;
        -> ¦
    Query OK, 0 rows affected (0.00 sec)
    Jusque la, tout va bien. Le probleme arrive quand je rajoute un DVD avec cette requete :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    INSERT  INTO  `dvd` (  `id` ,  `titre` ,  `annee` ,  `pays` ,  `anneeFilm`  ) 
    VALUES ( '',  'toto',  '0000-00-00',  'us',  '0000-00-00'
    )

    MySQL me retourne cette erreur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     #1136 - Column count doesn't match value count at row 1
    Je suis pas un pro de MySQL, est-ce que quelqu'un peut me depanner ? J'utilise MySQL 5.0.18, for Win32
    Merci

  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
    Bonjour,

    Le message d'erreur est explicite : le nombre de valeurs n'est pas celui attendu par rapport au nombre de colonnes.

    Il doit s'agir de cet INSERT :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    insert into stock values (NEW.id)
    à changer en :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    insert into stock (dvd) values (NEW.id)

  3. #3
    Membre à l'essai
    Inscrit en
    Novembre 2004
    Messages
    17
    Détails du profil
    Informations forums :
    Inscription : Novembre 2004
    Messages : 17
    Points : 12
    Points
    12
    Par défaut
    Salut,


    merci a toi, il y avait un probleme mais au niveau de l'autre INSERT... erreur de syntaxe, je n'utilise pas assez SQL pour le connaitre par coeur

    Encore merci

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

Discussions similaires

  1. [AC-2010] Erreur 3134 lors d'une insertion dans une table
    Par SYNEQUANON dans le forum Requêtes et SQL.
    Réponses: 11
    Dernier message: 09/05/2015, 10h32
  2. Réponses: 11
    Dernier message: 17/01/2008, 19h53
  3. erreur lors d''une insertion
    Par lilemy dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 18/06/2007, 10h54
  4. erreur lors d'une insertion
    Par poula dans le forum Oracle
    Réponses: 1
    Dernier message: 24/12/2006, 19h07
  5. Erreur lors d'une insertion
    Par chleuh dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 22/11/2006, 08h36

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