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 :

Champ auto_decrement ?


Sujet :

SQL Procédural MySQL

  1. #1
    J1
    J1 est déconnecté
    Membre averti Avatar de J1
    Inscrit en
    Mai 2004
    Messages
    321
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 321
    Points : 335
    Points
    335
    Par défaut Champ auto_decrement ?
    Bonjour,

    est-il possible en MySQL 4.1 de créer un champ auto_increment qui ne s'incrémente pas, mais au contraire se décrémente (-1 à chaque nouvel enregistrement) ?
    Je sais que c'est possible sous Access, mais je ne trouve pas cette option sous MySQL. En outre, comme je suis en MySQL 4.1, impossible de simuler ce comportement par trigger, j'aurais donc vraiment besoin d'une option native MySQL.

    Merci d'avance pour vos lumières.

  2. #2
    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
    A quoi ça servirait ???
    Antoun
    Expert Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  3. #3
    J1
    J1 est déconnecté
    Membre averti Avatar de J1
    Inscrit en
    Mai 2004
    Messages
    321
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 321
    Points : 335
    Points
    335
    Par défaut
    Ce serait long à expliquer. Pour faire très court, disons que c'est lié à une problématique de synchronisation entre bases de données, dont les ID ne doivent pas se chevaucher. L'objectif est donc que les ID d'une des bases s'incrémentent pendant que ceux de l'autre base se décrémentent.

    Comme je le disais, certains SGBD le permettent mais je n'ai pas trouvé d'option identique sous MySQL. Pourrais-tu me confirmer que MySQL ne le permet pas, s'il-te-plaît ?

  4. #4
    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
    Citation Envoyé par J1 Voir le message
    Pourrais-tu me confirmer que MySQL ne le permet pas, s'il-te-plaît ?
    Franchement, je n'en sais rien : je ne me suis jamais posé de question aussi tordue. Je crois que tu me confonds avec la doc .

    Si ça n'existe pas, tu peux par contre modifier la valeur courante de l'auto_increment (ALTER TABLE... AUTO_INCREMENT = ...). Tu pourrais ainsi avoir une table qui prend les ID de 1 à 99 999 et l'autre à partir de 100 000.
    Antoun
    Expert Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  5. #5
    J1
    J1 est déconnecté
    Membre averti Avatar de J1
    Inscrit en
    Mai 2004
    Messages
    321
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 321
    Points : 335
    Points
    335
    Par défaut
    Citation Envoyé par Antoun Voir le message
    Franchement, je n'en sais rien : je ne me suis jamais posé de question aussi tordue. Je crois que tu me confonds avec la doc .
    Non, en fait, c'est justement parce que j'ai déjà consulté la doc (et écumé Google) sans y trouver de solution que je te pose la question !

    Mais, après tout, il est possible que MySQL ne permette tout simplement pas l'"auto decrement".

    Citation Envoyé par Antoun Voir le message
    Si ça n'existe pas, tu peux par contre modifier la valeur courante de l'auto_increment (ALTER TABLE... AUTO_INCREMENT = ...). Tu pourrais ainsi avoir une table qui prend les ID de 1 à 99 999 et l'autre à partir de 100 000.
    Oui, je sais, mais sans rentrer dans de fastidieux détails, disons qu'un auto increment d'un côté et un "auto decrement" de l'autre résoudraient mon problème, là où deux auto increment "décalés" n'y parviendront malheureusement pas.

    Bon, de toute façon, entre mon premier message de janvier et maintenant, le projet de synchronisation sur lequel je travaille a pris une autre direction.

    Mais je dois avouer que, pour ma culture personnelle, j'aurais bien voulu savoir si l'auto decrement existait sous MySQL. C'est pourquoi je n'ai pas "delesté" le topic.

    En tout cas, merci pour ton aide, Antoun.

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

Discussions similaires

  1. comment remplacer une partie de texte dans un champs
    Par patlapi dans le forum Paradox
    Réponses: 4
    Dernier message: 20/11/2003, 14h38
  2. [VB6] [Datareport] définir un champ
    Par ckankonvahou dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 23/10/2002, 11h16
  3. [ADO] Constantes des types de champ
    Par SpaceFrog dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 05/09/2002, 11h08
  4. Taille des champs proportionnelle...
    Par Depteam1 dans le forum Composants VCL
    Réponses: 2
    Dernier message: 09/08/2002, 11h48
  5. taille max du nom d'un champ
    Par hna dans le forum Paradox
    Réponses: 2
    Dernier message: 28/07/2002, 02h40

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