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

 MySQL Discussion :

pb pour création de tables


Sujet :

MySQL

  1. #1
    Nouveau membre du Club
    Inscrit en
    Juillet 2008
    Messages
    35
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 35
    Points : 35
    Points
    35
    Par défaut pb pour création de tables
    Bonjour, je débute en mysql et 'jai un problème pour créer une table.

    voici le code :
    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
    CREATE  TABLE IF NOT EXISTS `swatk`.`CRITERE` (
      `idCritere` INT NOT NULL ,
      `idReferentiel` INT NOT NULL ,
      `idCategorie` INT NULL ,
      `idNiveau` INT NULL ,
      PRIMARY KEY (`idCritere`) ,
      INDEX `fkREF_CRI` (`idReferentiel` ASC) ,
      INDEX `fkNIV_CRI` (`idNiveau` ASC) ,
      INDEX `fkCAT_CRI` (`idCategorie` ASC) ,
      CONSTRAINT `fkREF_CRI`
        FOREIGN KEY (`idReferentiel` )
        REFERENCES `swatk`.`REFERENTIEL` (`idReferentiel` )
        ON DELETE NO ACTION
        ON UPDATE NO ACTION,
      CONSTRAINT `fkNIV_CRI`
        FOREIGN KEY (`idNiveau` )
        REFERENCES `swatk`.`NIVEAU` (`idNiveau` )
        ON DELETE NO ACTION
        ON UPDATE NO ACTION,
      CONSTRAINT `fkCAT_CRI`
        FOREIGN KEY (`idCategorie` )
        REFERENCES `swatk`.`CATEGORIE` (`idCategorie` )
        ON DELETE NO ACTION
        ON UPDATE NO ACTION)
    ENGINE = InnoDB
    COMMENT = 'ex : contenu non textuel';
    j'ai le message d'erreur suivant lorsque je l'exécute :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    #1005 - Can't create table 'swatk.critere' (errno: 121)
    il bloque à partir de la ligne "CONSTRAINT `fkREF_CRI`"

    mes trois tables "catégorie", "référentiel" et "niveau" ont bien été créé au préalable ainsi que leur clé primaire respective idCategorie, idReferentiel et idNiveau.

    merci pour votre aide car je bloque.

  2. #2
    Nouveau membre du Club
    Inscrit en
    Juillet 2008
    Messages
    35
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 35
    Points : 35
    Points
    35
    Par défaut
    J'ai l'impression qu'il ne peut pas à la fois créer l'index et en même temps poser la clé étrangère sur le même champ est ce que je me trompe?

  3. #3
    Membre éprouvé Avatar de Oishiiii
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2009
    Messages
    508
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Août 2009
    Messages : 508
    Points : 1 107
    Points
    1 107
    Par défaut
    Bonjour,

    Je pense que vous pouvez commencer par enlever les INDEX, puisque de toute façon MySQL créer automatiquement un index derrière chaque colonne clé étrangère.

    Ensuite, vérifiez bien que les colonnes auxquelles vous faites référence sont exactement du même type que les colonne clé étrangère.

    Edit:
    Modifiez les noms de vos indexs et de vos fk.
    Comme je l'ai dit MySQL créer implicitement un index derrière chaque FK, et pour le nom de l'index il utilise le nom de la FK. Donc la ça doit poser un problème.

  4. #4
    Nouveau membre du Club
    Inscrit en
    Juillet 2008
    Messages
    35
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 35
    Points : 35
    Points
    35
    Par défaut
    Merci de votre réponse elle me convient parfaitement.

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

Discussions similaires

  1. [AC-2010] Besoin coup de mains pour création des tables - Bulletin scolaire
    Par vincmori dans le forum Modélisation
    Réponses: 3
    Dernier message: 28/02/2011, 18h55
  2. [SQL] Petit aide pour création de table
    Par akrogames dans le forum Langage SQL
    Réponses: 2
    Dernier message: 25/01/2008, 14h09
  3. Critères multiples pour création de tables
    Par tissyseb dans le forum Modélisation
    Réponses: 1
    Dernier message: 31/10/2007, 10h40
  4. aide pour création de tables
    Par arti2004 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 18/06/2007, 12h08
  5. Requete sql pour création de table dans une base access
    Par Ben156 dans le forum Bases de données
    Réponses: 1
    Dernier message: 17/01/2006, 22h12

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