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

Développement SQL Server Discussion :

id autoincrémenté par trigger


Sujet :

Développement SQL Server

  1. #1
    Membre régulier
    Inscrit en
    Octobre 2005
    Messages
    273
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 273
    Points : 118
    Points
    118
    Par défaut id autoincrémenté par trigger
    Bonjour à tous. J'aurais aimer savoir comment faire pour autoincrémenter un id par exemple lors d'une insertion. Sur oracle je faisais ceci:

    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
     
    CREATE SEQUENCE IDVISITEUR START WITH 1 INCREMENT BY 1;
     
    CREATE TRIGGER Trg_NewVisiteur
     
    BEFORE INSERT  ON Visiteurs
    FOR EACH ROW
    DECLARE
        Nr VARCHAR2(14) ;
    	X INTEGER;
    BEGIN
     
    	SELECT IDVISITEUR.nextval INTO X FROM DUAL;
            Nr:=CAST(X AS VARCHAR2);
    	:NEW.IdVisiteur:=Nr;
     
    END;
    /
    Mais ce système ne fonctionne pas avec sql server 2005 ... il ne reconnait pas la séquence

    Si qqu peut m'aider ... merci

  2. #2
    Membre expert
    Avatar de TheLeadingEdge
    Inscrit en
    Mai 2005
    Messages
    1 199
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 1 199
    Points : 3 103
    Points
    3 103
    Par défaut
    bonjour,

    SqlServer permet de gérer directement des clefs autoincrémentées sans passer par des triggers
    Par ex.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    IdVisiteur INTEGER NOT NULL IDENTITY (1,1)

  3. #3
    Membre régulier
    Inscrit en
    Octobre 2005
    Messages
    273
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 273
    Points : 118
    Points
    118
    Par défaut
    :s je suis désolé mais j'ai commencé avec sql server 2005 y a qq jours ... je vois pas ou je dois faire ca .... j'utilise SQL Server Management Studio Express CTP ... Je vois pas du tt ou je dois aller pour modifier une propriété de mon champ pour lui indiquer qu'il doit être auto incrémenté

  4. #4
    Membre expert
    Avatar de TheLeadingEdge
    Inscrit en
    Mai 2005
    Messages
    1 199
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 1 199
    Points : 3 103
    Points
    3 103
    Par défaut
    re,

    A la création de la table.
    ex:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    CREATE TABLE visiteurs
    ( 
          IdVisiteur INTEGER NOT NULL IDENTITY (1,1),
          ...
          PRIMARY KEY (IdVisiteur) 
    );

  5. #5
    Membre régulier
    Inscrit en
    Octobre 2005
    Messages
    273
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 273
    Points : 118
    Points
    118
    Par défaut
    merci pour tt ca fonctionne

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

Discussions similaires

  1. Ajouter ou mettre à jour par trigger
    Par Genohunter dans le forum SQL Procédural
    Réponses: 8
    Dernier message: 19/09/2008, 14h11
  2. Maj par trigger
    Par RSI06 dans le forum PL/SQL
    Réponses: 17
    Dernier message: 16/11/2007, 17h24
  3. modification d'un champs par trigger
    Par witch dans le forum SQL Procédural
    Réponses: 17
    Dernier message: 06/10/2007, 19h50
  4. Clefs primaires assignées par trigger
    Par Costalfy dans le forum Hibernate
    Réponses: 8
    Dernier message: 10/08/2007, 11h59
  5. RAISE_APPLICATION_ERROR + INSERT déclenchés par trigger
    Par petit_crabe dans le forum PL/SQL
    Réponses: 2
    Dernier message: 26/06/2007, 15h11

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