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 :

doubler les clés primaires est ce possible?


Sujet :

MySQL

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 106
    Points : 50
    Points
    50
    Par défaut doubler les clés primaires est ce possible?
    Bonjour,

    Je débute sur MYSQL et j'ai une question:

    Je voudrais construire un table avec 2 colonnes.

    La premiere contient un pseudo qui doit etre unique(primary key) (nick)

    La deuxièmte contient un entier sur 10 chiffres qui lui aussi doit etre unique(primary key) et je met un auto incrément dessus. (picp)

    voici ma table:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    CREATE  TABLE IF NOT EXISTS `photos_main` ( 
    `nick` VARCHAR(20) NOT NULL , 
    ’picp` INT UNSIGNED ZEROFILL NOT NULL AUTO_INCREMENT ,  
    PRIMARY KEY (`picp`, `nick`) ,  
    CONSTRAINT `nick_ml_p_fk`  
    FOREIGN KEY (`nick` )  REFERENCES `member_list` (`nick` )  
    ON DELETE CASCADE  
    ON UPDATE 
    NO ACTION
    ) 
    ENGINE = InnoDB 
    DEFAULT CHARACTER SET = latin1
    Quand je fais des essais , la colonne picp est bien auto incrementée
    par contre si je refais une insertion identique, cela est accepté avec le meme pseudo et une valeur picp différente par MYSQL alors que j'ai mis egalement ma premiere colonne en primary key

    Comment cela se fait il?

    j'ai vraiment besoin que chaque colonne soit unique comment faire?

    Merci de votre aide.


  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Une table ne peut comporter qu'une seule clef primaire.
    Néanmoins, une clef primaire finalement ce n'est que l'association de deux contraintes : UNIQUE et NOT NULL.

    Créez votre table de la façon suivante :
    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
    CREATE TABLE photos_main
    ( 
      picp INT UNSIGNED ZEROFILL NOT NULL AUTO_INCREMENT,  
      nick VARCHAR(20)           NOT NULL               , 
      CONSTRAINT pk_photos_main
        PRIMARY KEY (picp)                              ,
      CONSTRAINT ak_photos_main
        UNIQUE INDEX (nick)                             ,
      CONSTRAINT nick_ml_p_fk
        FOREIGN KEY (nick)
        REFERENCES member_list (nick)  
        ON DELETE CASCADE  
        ON UPDATE NO ACTION
    ) 
    ENGINE = InnoDB 
    DEFAULT CHARACTER SET = latin1
    Il doit sûrement manquer des petites options ici ou là, je vous laisse compléter.

  3. #3
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 281
    Points : 11 737
    Points
    11 737
    Par défaut
    Pour compléter la réponse de Waldar :

    - par définition, la clé primaire est un choix parmi les clés possibles (dites "candidates") ; il n'y en a donc qu'une

    - les candidates non retenues ont évidemment vocation à porter un index UNIQUE

    - enfin, MySQL ne permet le numéro auto-incrémenté que sur la clé primaire (d'où le choix de Waldar de retenir le n° comme primaire plutôt que le pseudo)
    Antoun
    Expert Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 106
    Points : 50
    Points
    50
    Par défaut merci
    Vos réponses m'ont bien aidé.

    Je ne savais pas que l'on pouvait se servir des index pour eviter les doublons d'entrée.

    Je pensais que deux clés primaires etait possible.

    Merci d'avoir comblé une (petite) partie de mon ignorance.


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

Discussions similaires

  1. [Clés primaires] Est ce possible de les modifier ?
    Par dynexd dans le forum Access
    Réponses: 3
    Dernier message: 29/09/2006, 14h03
  2. Récupérer les clés primaires "perdues"
    Par Dnx dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 12/07/2006, 17h13
  3. Récupérer les mot-clés Google, est-ce possible ?
    Par kurtalis dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 12/05/2006, 18h48
  4. [EJB2.1 Entity] [CMP] [xdoclet] Problème avec les clés primaires
    Par shingo dans le forum Java EE
    Réponses: 1
    Dernier message: 10/02/2006, 16h41
  5. [C#] Probleme sur les clés primaires composites
    Par stardeus dans le forum Windows Forms
    Réponses: 7
    Dernier message: 12/02/2005, 23h28

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