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

MS SQL Server Discussion :

Réoganiser l'autoincrementation apres une suppression


Sujet :

MS SQL Server

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    63
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 63
    Points : 28
    Points
    28
    Par défaut Réoganiser l'autoincrementation apres une suppression
    Salut à tous,

    je sais pas si je raconte pas de bêtises ? je m'explique j'ai une base de données possèdant 7 tables dont une principale qui est renseignée par les 6 autres tables .
    la colonne qui permet le lien entre la tables principale et les 6 autres tables (PK-FK) est un autoincrement (ID).

    j'ai crée un trigger qui à chaque nouvelle insertion dans les 6 autres tables, le ID s'autoincremnte.
    Mon probleme c'est dès que je veux supprimer une ligne l'insertion ne marche plus ! il me dit que y a un conflit entre l'insertion et le trigger !

    mon trigger est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    CREATE TRIGGER autoincrement_elements
          on dbo.ARTICLE_ELEMENTS
          instead of insert
          as
          declare @newid int
          begin
              select @newid = isnull(min(t1.reference_id), 0) + 1
              from ARTICLE_ELEMENTS t1
              where not exists (select null from ARTICLE_ELEMENTS t2 where t2.reference_id = t1.reference_id + 1)
              insert into ARTICLE_ELEMENTS (reference_id, element_nom) select @newid, element_nom from inserted 
          end
    c'est pour cela que je me demande est ce que c'est possible de réorganiser l'autoincrémentation apres une suppression ??
    merci de votre aide

  2. #2
    Membre averti
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    356
    Détails du profil
    Informations personnelles :
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Mai 2007
    Messages : 356
    Points : 406
    Points
    406
    Par défaut
    Tu peux rechercher du côté de la commande DBCC CHECKIDENT qui permet de réinitialiser la valeur du compteur d'autoincrémentation.

    Peut-être que cette commande pourra t'ouvrir des perpectivers de résolution de ton problème ?

    Tiens nous au courant.

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    63
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 63
    Points : 28
    Points
    28
    Par défaut
    merci Madinico je vais voir ça !

Discussions similaires

  1. Tableau : ordonner les clés après une suppression
    Par renaud26 dans le forum Langage
    Réponses: 1
    Dernier message: 23/06/2009, 16h43
  2. [Utilisation] Comment reprendre après une suppression du trunk ?
    Par gdeblonde dans le forum Subversion
    Réponses: 0
    Dernier message: 19/02/2009, 15h10
  3. Réponses: 4
    Dernier message: 05/11/2008, 21h17
  4. Réponses: 1
    Dernier message: 17/11/2007, 20h55
  5. Changer la valeur ID après une suppression
    Par VFone dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 13/10/2007, 19h15

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