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 Oracle Discussion :

Combler les trous ID_AUTO


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Apprentie Ingé
    Inscrit en
    Septembre 2012
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Apprentie Ingé
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Septembre 2012
    Messages : 43
    Par défaut Combler les trous ID_AUTO
    Bonjour,

    Mon dernier post monte à très longtemps mais je me retrouve dans le besoin d'un peu d'aide.
    Je me retrouve dans la situation où j'alimente une table avec des TAG liés à un ID auto incrémenté.
    Les TAG "A" sont ajoutés manuellement et les TAG "B" automatiquement.
    Je supprime tous les matins les lignes contenant le TAG "B" et relance la mécanique automatique d'ajout des TAG "B".

    Le problème : Si un TAG "A" est ajouté manuellement après des TAG "B" je me retrouve avec des trous dans mes ID pouvant être des trous allant de décalage de 200 sur mes deux ID ...
    Mon champ ID est limité à 999 du coup en deux trois fois je me retrouve avec mon max atteint et je ne souhaite pas que cette ID atteigne plus de 999.
    (voir exemple ci-dessous)

    Début :
    id | TAG
    1 | A
    2 | A
    3 | A
    4 | B
    5 | B
    6 | A
    7 | A

    Finalité ... :
    id | TAG
    1 | A
    2 | A
    3 | A
    6 | A
    7 | A

    Comment faire pour que mes id 6 et 7 passent à 4 et 5 dans le but de ne pas me retrouver avec ces "creux"

    Final :
    id | TAG
    1 | A
    2 | A
    3 | A
    4 | A
    5 | A

    Si je ne suis pas assez précis je peux reformuler ma demande !
    Merci d'avance

  2. #2
    Modérateur
    Avatar de kolodz
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2008
    Messages
    2 209
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 209
    Billets dans le blog
    52
    Par défaut
    Pour être sûr d'avoir compris le problème :
    En gros, tu as une table avec un auto incrément où tu as un certains nombre de valeurs "temporaires" qui sont supprimé et recréer tout les jours.
    Tu rencontre un problème la suppression/création de tes valeurs "temporaires" ne sont pas les dernières valeurs dans ta table.

    Si tu n'as pas de référence sur ta table. Il n'est possible de faire quelque chose dans ce style :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select distinct ID,  row_number() over (order by ID) from TAG_TABLE where ROWNUM<ID;
    Cette requête devrait te retourner l'ensemble des lignes ayant un ID supérieur à son Identifiant théorique.

    Il ne reste plus qu'à mettre à jour la table en fonction, ainsi que les références.

    Cordialement,
    Patrick Kolodziejczyk.
    Si une réponse vous a été utile pensez à
    Si vous avez eu la réponse à votre question, marquez votre discussion
    Pensez aux FAQs et aux tutoriels et cours.

  3. #3
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    Citation Envoyé par Thryfto Voir le message
    ...
    Si je ne suis pas assez précis je peux reformuler ma demande !
    Oui pas assez précis!
    Est-ce que vous voulez juste afficher un sorte de numéro d'ordre pour les tags A ou B ? Ou est-ce que vous cherchez comment remplacer des valeurs uniques issues des séquences, qui forcement peuvent avoir des trous, avec des valeurs incrémentées par un mécanisme quelconque mais sans trou ?

  4. #4
    Membre averti
    Homme Profil pro
    Apprentie Ingé
    Inscrit en
    Septembre 2012
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Apprentie Ingé
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Septembre 2012
    Messages : 43
    Par défaut
    Citation Envoyé par mnitu Voir le message
    Oui pas assez précis!
    Est-ce que vous voulez juste afficher un sorte de numéro d'ordre pour les tags A ou B ? Ou est-ce que vous cherchez comment remplacer des valeurs uniques issues des séquences, qui forcement peuvent avoir des trous, avec des valeurs incrémentées par un mécanisme quelconque mais sans trou ?
    Je reformule du coup ahah, le but serait comme le titre l'indique de combler les trous entre mes ID avec les données qui ne sont jamais supprimées (TAG "A").
    Mes TAG "A" sont des données fixes de ce fait je souhaiterai que tous ces TAG se suivent pour qu'au prochain DELETE / INSERT des TAG "B" il n'y ai pas ou plus de trous possibles.

    Pour en revenir à l'exemple je cherche simplement à identifier les trous après suppression du TAG B et les combler par mes données non supprimés TAG A.
    id | TAG
    1 | A
    2 | A
    3 | A
    6 | A
    7 | A

    Vers

    id | TAG
    1 | A
    2 | A
    3 | A
    4 | A
    5 | A

    La solution de "kolodz" et son approche semble correspondre à mon problème j'essaie d'appliquer ça et je reviens vers vous =)

Discussions similaires

  1. Combler les "trous" d'une séquence
    Par SergioMaster dans le forum Langage SQL
    Réponses: 6
    Dernier message: 26/02/2016, 11h04
  2. Combler les trous de valeur dans un calendrier
    Par olibara dans le forum Développement
    Réponses: 4
    Dernier message: 11/09/2015, 10h55
  3. Combler les trous d'autoNum
    Par Stéphane Olivier BERNARD dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 10/10/2007, 16h25
  4. combler les trous d'un id sous mysql
    Par D.Mounir dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 02/05/2007, 10h29
  5. Combler les trous lors d'une suppression dans une table
    Par Billybongjoe dans le forum PostgreSQL
    Réponses: 5
    Dernier message: 08/04/2004, 14h02

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