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 :

ERROR: Error 1062: Duplicate entry ** for key 'user.PRIMARY' et aide MySQL Workbench


Sujet :

MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2016
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2016
    Messages : 10
    Par défaut ERROR: Error 1062: Duplicate entry ** for key 'user.PRIMARY' et aide MySQL Workbench
    Bonjour à tous,

    je débute avec MySQL et j'utlise MYSQL Workbench pour la création de mes tables ainsi que l'exportation vers ma base de données. Pour faire cette etape je crée mes table et j’utilise "Forwar Engineer Ctrl+G" pour générer ma BDD.
    Code sql : 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
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    -- MySQL Workbench Forward Engineering
     
    SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0;
    SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0;
    SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
     
    -- -----------------------------------------------------
    -- Schema mydb
    -- -----------------------------------------------------
     
    -- -----------------------------------------------------
    -- Schema mydb
    -- -----------------------------------------------------
    CREATE SCHEMA IF NOT EXISTS `mydb` DEFAULT CHARACTER SET utf8 ;
    USE `mydb` ;
     
    -- -----------------------------------------------------
    -- Table `mydb`.`user`
    -- -----------------------------------------------------
    CREATE TABLE IF NOT EXISTS `mydb`.`user` (
      `username` VARCHAR(16) NOT NULL,
      `email` VARCHAR(255) NOT NULL,
      `password` VARCHAR(32) NOT NULL,
      `create_time` TIMESTAMP NULL DEFAULT CURRENT_TIMESTAMP,
      PRIMARY KEY (`username`));
     
     
    -- -----------------------------------------------------
    -- Table `mydb`.`Projets`
    -- -----------------------------------------------------
    CREATE TABLE IF NOT EXISTS `mydb`.`Projets` (
      `idProjets` VARCHAR(45) NOT NULL,
      `Date` DATE NOT NULL,
      `Lieu` VARCHAR(45) NOT NULL,
      `Code Postal` DECIMAL(5) NOT NULL,
      PRIMARY KEY (`idProjets`))
    ENGINE = InnoDB;
     
     
    -- -----------------------------------------------------
    -- Table `mydb`.`user_has_Projets`
    -- -----------------------------------------------------
    CREATE TABLE IF NOT EXISTS `mydb`.`user_has_Projets` (
      `user_username` VARCHAR(16) NOT NULL,
      `Projets_idProjets` VARCHAR(45) NOT NULL,
      PRIMARY KEY (`user_username`, `Projets_idProjets`),
      INDEX `fk_user_has_Projets_Projets1_idx` (`Projets_idProjets` ASC) INVISIBLE,
      INDEX `fk_user_has_Projets_user_idx` (`user_username` ASC) VISIBLE,
      CONSTRAINT `fk_user_has_Projets_user`
        FOREIGN KEY (`user_username`)
        REFERENCES `mydb`.`user` (`username`)
        ON DELETE NO ACTION
        ON UPDATE NO ACTION,
      CONSTRAINT `fk_user_has_Projets_Projets1`
        FOREIGN KEY (`Projets_idProjets`)
        REFERENCES `mydb`.`Projets` (`idProjets`)
        ON DELETE NO ACTION
        ON UPDATE NO ACTION);
     
     
    SET SQL_MODE=@OLD_SQL_MODE;
    SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS;
    SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;
     
    -- -----------------------------------------------------
    -- Data for table `mydb`.`user`
    -- -----------------------------------------------------
    START TRANSACTION;
    USE `mydb`;
    INSERT INTO `mydb`.`user` (`username`, `email`, `password`, `create_time`) VALUES ('Nassim MOKHTARI', 'nassim.mokhtari@****', '1234', NULL);
     
    COMMIT;
     
     
    -- -----------------------------------------------------
    -- Data for table `mydb`.`Projets`
    -- -----------------------------------------------------
    START TRANSACTION;
    USE `mydb`;
    INSERT INTO `mydb`.`Projets` (`idProjets`, `Date`, `Lieu`, `Code Postal`) VALUES ('50001', '13-03-2020', 'Saint lo', 50000);
    INSERT INTO `mydb`.`Projets` (`idProjets`, `Date`, `Lieu`, `Code Postal`) VALUES ('50002', '13-03-2020', 'Saint lo', 50000);
    INSERT INTO `mydb`.`Projets` (`idProjets`, `Date`, `Lieu`, `Code Postal`) VALUES ('14001', '12-02-2020', 'caen', 14000);
    INSERT INTO `mydb`.`Projets` (`idProjets`, `Date`, `Lieu`, `Code Postal`) VALUES ('14002', '11-01-2020', 'caen', 14000);
     
    COMMIT;
     
    -- -----------------------------------------------------
    -- Data for table `mydb`.`user_has_Projets`
    -- -----------------------------------------------------
    START TRANSACTION;
    USE `mydb`;
    INSERT INTO `mydb`.`user_has_Projets` (`user_username`, `Projets_idProjets`) VALUES ('Nassim MOKHTARI', '50001');
     
    COMMIT;

    Mais ça fait l'erreur suivant:

    Executing SQL script in server
    ERROR: Error 1062: Duplicate entry 'Nassim MOKHTARI' for key 'user.PRIMARY'
    SQL Code:
    INSERT INTO `mydb`.`user` (`username`, `email`, `password`, `create_time`) VALUES ('Nassim MOKHTARI', 'nassim.mokhtari@axians.com', '1234', NULL)

    SQL script execution finished: statements: 13 succeeded, 1 failed

    Fetching back view definitions in final form.
    Nothing to fetch
    Je ne comprend tout le problème malgré ma recherche sur les différents forum.

    Je serai aussi preneur de toute astuce et lien pour apprendre à utiliser cet outil pour crée une base de donnée de A a Z pour une entreprise.

    Merci par avance de m'aider dans mon problème.

    Cordialement

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 135
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 135
    Par défaut
    Tu es sur que ta table ne contient pas déjà cet identifiant quand tu essayes d'ajouter cette ligne ?
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2016
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2016
    Messages : 10
    Par défaut
    Merci pour ta réponse.

    On effet, mon soucis viens de fait que ma DB a été crée même si y a eu une erreur juste avant, du coup la table en question et ses colonnes était déjà crée.

    Mon erreur était ma fausse manip de "Forwar Engineer Ctrl+G" pour exporter les nouvelle données saisies.

    Dans ce cas, je suis preneur de conseil d'utlisation de worbench pour faire corriger juste une erreur si y a lieu sans passer par "forwar Engineer"

    D'avance Merci

  4. #4
    Expert éminent
    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 818
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 818
    Billets dans le blog
    14
    Par défaut
    Dans ce cas, je suis preneur de conseil d'utlisation de worbench pour faire corriger juste une erreur si y a lieu sans passer par "forwar Engineer"
    Une requête SQL pour effectuer la modif.

    Si c'est un ensemble de modifs qui se sont arêtées quelque part, générer le script SQL d'export vers la BDD puis commenter tout ce qui a déjà été mis dans la BDD et exécuter le reste du script. Ou bien détruire la BDD et la réexporter depuis Workbench s'il n'y a pas de risque de perdre des données en route.
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole, en retraite... mais toujours Autoentrepreneur à l'occasion.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

Discussions similaires

  1. Réponses: 0
    Dernier message: 08/01/2019, 23h15
  2. #1062 - Duplicate entry for key 'unicity'
    Par Avatar dans le forum Requêtes
    Réponses: 2
    Dernier message: 04/11/2015, 10h49
  3. [MySQL] UPDATE: ERROR DUPLICATE ENTRY FOR KEY PRIMARY
    Par Blackcocktail dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 19/12/2011, 15h07
  4. Réponses: 3
    Dernier message: 02/06/2011, 16h47
  5. Réponses: 7
    Dernier message: 29/11/2010, 17h34

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