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 :

Faire commencer l'AUTO INCREMENT à 0


Sujet :

MySQL

  1. #1
    Membre habitué Avatar de Coeur de Pirat
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2016
    Messages
    82
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2016
    Messages : 82
    Points : 150
    Points
    150
    Par défaut Faire commencer l'AUTO INCREMENT à 0
    Bonjour à tous

    J'ai une table où j'ai effectué des suppressions, donc mon id n'est plus dans l'ordre et il commence par 2, puis 6 etc.

    J'ai essayé de supprimer cet id et puis de le réinsérer à nouveau mais cela me cause des bugs, ça marche pas !

    Merci de votre aide

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    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 080
    Points : 30 803
    Points
    30 803
    Par défaut
    Citation Envoyé par Coeur de Pirat Voir le message
    cela me cause des bugs, ça marche pas !
    Pas très explicite comme description du problème
    La règle la plus communément admise est que ON NE MODIFIE PAS LA VALEUR D'UN IDENTIFIANT AUTO-INCREMENTE.
    C'est un identifiant technique, sans signification fonctionnelle. Si tu veux un identifiant fonctionnel auto-incrémenté (numéro de facture, de colis...) sans "trous", il faudra le gérer à la main.
    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
    Expert éminent sénior Avatar de Artemus24
    Homme Profil pro
    Agent secret au service du président Ulysses S. Grant !
    Inscrit en
    Février 2011
    Messages
    6 381
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Agent secret au service du président Ulysses S. Grant !
    Secteur : Finance

    Informations forums :
    Inscription : Février 2011
    Messages : 6 381
    Points : 19 065
    Points
    19 065
    Par défaut
    Salut Coeur de Pirat.

    Normalement, on ne bidouille pas dans l'identifiant auto incrémenté.
    Si son amplitude est trop petite, on peut mettre soit "integer unsigned" ou encore "bigint unsigned".
    Et s'il y a des trous, c'est pas bien grave !

    Mais à vos risques et périls, on peut faire une renumérotation comme dans l'exemple ci-après.
    Il y a deux tables, l'une père et l'autre fils qui sont liées par une clef étrangère.
    Il y a des trous dans la table père.
    Il faut vérifier que la "foreign key" appliquer bien le "update cascade" pour propager ce changement de numérotation.
    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
    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
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    --------------
    SET AUTOCOMMIT = 0
    --------------
     
    --------------
    START TRANSACTION
    --------------
     
    --------------
    DROP DATABASE IF EXISTS `base`
    --------------
     
    --------------
    CREATE DATABASE IF NOT EXISTS `base`
            DEFAULT CHARACTER SET `latin1`
            DEFAULT COLLATE       `latin1_general_ci`
    --------------
     
    --------------
    DROP TABLE IF EXISTS `pere`
    --------------
     
    --------------
    CREATE TABLE `pere` (
      `id`    integer unsigned NOT NULL AUTO_INCREMENT PRIMARY KEY,
      `val`   varchar(10)      NOT NULL
    ) ENGINE=InnoDB
      DEFAULT CHARSET=`latin1` COLLATE=`latin1_general_ci`
      ROW_FORMAT=COMPRESSED
    --------------
     
    --------------
    INSERT INTO `pere` (`id`, `val`) VALUES
    (25, 'bleu'),(75, 'rouge'),(255, 'vert'),(480, 'jaune')
    --------------
     
    --------------
    select * from pere
    --------------
     
    +-----+-------+
    | id  | val   |
    +-----+-------+
    |  25 | bleu  |
    |  75 | rouge |
    | 255 | vert  |
    | 480 | jaune |
    +-----+-------+
    --------------
    DROP TABLE IF EXISTS `fils`
    --------------
     
    --------------
    CREATE TABLE `fils` (
      `id`      integer unsigned NOT NULL AUTO_INCREMENT PRIMARY KEY,
      `clef`    integer unsigned NOT NULL,
      `nuance`  varchar(10)      NOT NULL,
      CONSTRAINT `fk_fils_clef` FOREIGN KEY (`clef`) REFERENCES `pere` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
    ) ENGINE=InnoDB
      DEFAULT CHARSET=`latin1` COLLATE=`latin1_general_ci`
      ROW_FORMAT=COMPRESSED
    --------------
     
    --------------
    INSERT INTO `fils` (`clef`, `nuance`) VALUES
    (25, 'marine'),    (75, 'carmin'),(255, 'pomme'),    (480, 'citron'),
    (25, 'nuit'),      (75, 'vif'),   (255, 'émeraude'), (480, 'pâle'),
    (25, 'turquoise'), (25, 'cyan'),  (255, 'olive')
    --------------
     
    --------------
    select * from fils
    --------------
     
    +----+------+-----------+
    | id | clef | nuance    |
    +----+------+-----------+
    |  1 |   25 | marine    |
    |  2 |   75 | carmin    |
    |  3 |  255 | pomme     |
    |  4 |  480 | citron    |
    |  5 |   25 | nuit      |
    |  6 |   75 | vif       |
    |  7 |  255 | émeraude  |
    |  8 |  480 | pâle      |
    |  9 |   25 | turquoise |
    | 10 |   25 | cyan      |
    | 11 |  255 | olive     |
    +----+------+-----------+
    --------------
    select p.id     as 'Père ID',
           p.val    as 'Père VAL',
           f.id     as 'Fils ID',
           f.nuance as 'Fils NUANCE'
    from       pere as p
    inner join fils as f
    on f.clef = p.id
    --------------
     
    +---------+----------+---------+-------------+
    | Père ID | Père VAL | Fils ID | Fils NUANCE |
    +---------+----------+---------+-------------+
    |      25 | bleu     |       1 | marine      |
    |      25 | bleu     |       5 | nuit        |
    |      25 | bleu     |       9 | turquoise   |
    |      25 | bleu     |      10 | cyan        |
    |      75 | rouge    |       2 | carmin      |
    |      75 | rouge    |       6 | vif         |
    |     255 | vert     |       3 | pomme       |
    |     255 | vert     |       7 | émeraude    |
    |     255 | vert     |      11 | olive       |
    |     480 | jaune    |       4 | citron      |
    |     480 | jaune    |       8 | pâle        |
    +---------+----------+---------+-------------+
    --------------
    update `pere`, (select @x:=0) as x set id = (@x:=@x+1)
    --------------
     
    --------------
    select * from pere
    --------------
     
    +----+-------+
    | id | val   |
    +----+-------+
    |  1 | bleu  |
    |  2 | rouge |
    |  3 | vert  |
    |  4 | jaune |
    +----+-------+
    --------------
    select * from fils
    --------------
     
    +----+------+-----------+
    | id | clef | nuance    |
    +----+------+-----------+
    |  1 |    1 | marine    |
    |  2 |    2 | carmin    |
    |  3 |    3 | pomme     |
    |  4 |    4 | citron    |
    |  5 |    1 | nuit      |
    |  6 |    2 | vif       |
    |  7 |    3 | émeraude  |
    |  8 |    4 | pâle      |
    |  9 |    1 | turquoise |
    | 10 |    1 | cyan      |
    | 11 |    3 | olive     |
    +----+------+-----------+
    --------------
    select p.id     as 'Père ID',
           p.val    as 'Père VAL',
           f.id     as 'Fils ID',
           f.nuance as 'Fils NUANCE'
    from       pere as p
    inner join fils as f
    on f.clef = p.id
    --------------
     
    +---------+----------+---------+-------------+
    | Père ID | Père VAL | Fils ID | Fils NUANCE |
    +---------+----------+---------+-------------+
    |       1 | bleu     |       1 | marine      |
    |       1 | bleu     |       5 | nuit        |
    |       1 | bleu     |       9 | turquoise   |
    |       1 | bleu     |      10 | cyan        |
    |       2 | rouge    |       2 | carmin      |
    |       2 | rouge    |       6 | vif         |
    |       3 | vert     |       3 | pomme       |
    |       3 | vert     |       7 | émeraude    |
    |       3 | vert     |      11 | olive       |
    |       4 | jaune    |       4 | citron      |
    |       4 | jaune    |       8 | pâle        |
    +---------+----------+---------+-------------+
    --------------
    COMMIT
    --------------
     
    --------------
    SET AUTOCOMMIT = 1
    --------------
     
     
    Appuyez sur une touche pour continuer...
    Pour renuméroter, c'est ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    update `pere`, (select @x:=0) as x set id = (@x:=@x+1)
    @+
    Si vous êtes de mon aide, vous pouvez cliquer sur .
    Mon site : http://www.jcz.fr

  4. #4
    Membre habitué Avatar de Coeur de Pirat
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2016
    Messages
    82
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2016
    Messages : 82
    Points : 150
    Points
    150
    Par défaut
    Merci Artemus 24. ça marche

    j'ai finalement pas ôté l'id_champ, je l'ai renuméroter avec ce code.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    update `champ`, (select @x:=0) as x set id_champ = (@x:=@x+1)
    Parfait, merci beaucoup.

  5. #5
    Expert éminent sénior Avatar de Artemus24
    Homme Profil pro
    Agent secret au service du président Ulysses S. Grant !
    Inscrit en
    Février 2011
    Messages
    6 381
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Agent secret au service du président Ulysses S. Grant !
    Secteur : Finance

    Informations forums :
    Inscription : Février 2011
    Messages : 6 381
    Points : 19 065
    Points
    19 065
    Par défaut
    Salut Coeur de Pirat.

    Citation Envoyé par Coeur de Pirat
    J'ai essayé de supprimer cet id et puis de le réinsérer à nouveau mais cela me cause des bugs, ça marche pas !
    C'est pourtant pas difficile de détruire une colonne et de la recréer, même si c'est une primary key.
    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
    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
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    --------------
    SET AUTOCOMMIT = 0
    --------------
     
    --------------
    START TRANSACTION
    --------------
     
    --------------
    DROP DATABASE IF EXISTS `base`
    --------------
     
    --------------
    CREATE DATABASE IF NOT EXISTS `base`
            DEFAULT CHARACTER SET `latin1`
            DEFAULT COLLATE       `latin1_general_ci`
    --------------
     
    --------------
    drop table if exists `test`
    --------------
     
    --------------
    CREATE TABLE `test` (
      `id`    integer unsigned  NOT NULL auto_increment primary key,
      `val`   char(10)              NULL default NULL
    ) ENGINE=InnoDB
      DEFAULT CHARSET=`latin1` COLLATE=`latin1_general_ci`
      ROW_FORMAT=COMPRESSED
    --------------
     
    --------------
    insert into `test` (`id`,`val`) values (1, 'un'),(33, 'deux'),(75, 'trois'),(207, 'quatre'),(349, 'cinq'),(711, 'six'),(813, 'sept')
    --------------
     
    --------------
    select * from  `test`
    --------------
     
    +-----+--------+
    | id  | val    |
    +-----+--------+
    |   1 | un     |
    |  33 | deux   |
    |  75 | trois  |
    | 207 | quatre |
    | 349 | cinq   |
    | 711 | six    |
    | 813 | sept   |
    +-----+--------+
    --------------
    SELECT AUTO_INCREMENT as last_id
    FROM   INFORMATION_SCHEMA.TABLES
    WHERE  table_schema = 'base' and table_name = 'test'
    --------------
     
    +---------+
    | last_id |
    +---------+
    |     814 |
    +---------+
    --------------
    commit
    --------------
     
    --------------
    alter table `test` drop column `id`
    --------------
     
    --------------
    alter table `test` add  column `id` integer unsigned auto_increment not null primary key first
    --------------
     
    --------------
    describe `test`
    --------------
     
    +-------+------------------+------+-----+---------+----------------+
    | Field | Type             | Null | Key | Default | Extra          |
    +-------+------------------+------+-----+---------+----------------+
    | id    | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
    | val   | char(10)         | YES  |     | NULL    |                |
    +-------+------------------+------+-----+---------+----------------+
    --------------
    select * from  `test`
    --------------
     
    +----+--------+
    | id | val    |
    +----+--------+
    |  1 | un     |
    |  2 | deux   |
    |  3 | trois  |
    |  4 | quatre |
    |  5 | cinq   |
    |  6 | six    |
    |  7 | sept   |
    +----+--------+
    --------------
    SELECT AUTO_INCREMENT as last_id
    FROM   INFORMATION_SCHEMA.TABLES
    WHERE  table_schema = 'base' and table_name = 'test'
    --------------
     
    +---------+
    | last_id |
    +---------+
    |       8 |
    +---------+
    --------------
    COMMIT
    --------------
     
    --------------
    SET AUTOCOMMIT = 1
    --------------
     
     
    Appuyez sur une touche pour continuer...
    Fais-tu grève ?

    @+
    Si vous êtes de mon aide, vous pouvez cliquer sur .
    Mon site : http://www.jcz.fr

  6. #6
    Membre habitué Avatar de Coeur de Pirat
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2016
    Messages
    82
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2016
    Messages : 82
    Points : 150
    Points
    150
    Par défaut
    Salut Artemus 24,

    ce n'était pas le cas pour moi, je ne sais pas, ça doit être une fausse manipulation de ma part, autant pour moi.
    Je vais refaire le test et je te tiendrai au courant.

    Par contre je viens de poster une question sur une requête de sélection qui m'est difficile, peux-tu regarder si t'as une piste si c'est possible.

    Merci bien
    @+

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

Discussions similaires

  1. faire commencer l'AUTO INCREMENT à 0
    Par pazze dans le forum Débuter
    Réponses: 6
    Dernier message: 02/09/2012, 20h19
  2. Réponses: 8
    Dernier message: 06/12/2005, 11h33
  3. Auto Increment
    Par Guizz dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 23/06/2003, 18h36
  4. Nom du champs auto-incrementé
    Par norroy dans le forum Requêtes
    Réponses: 2
    Dernier message: 17/06/2003, 18h30
  5. Pb d'auto-incrément sur une table v7
    Par Nivux dans le forum Paradox
    Réponses: 9
    Dernier message: 26/12/2002, 12h05

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