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 :

SET Primary Key et identity sur colonne existante


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre expérimenté
    Profil pro
    Mangeur de gauffre
    Inscrit en
    Octobre 2007
    Messages
    4 413
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Mangeur de gauffre

    Informations forums :
    Inscription : Octobre 2007
    Messages : 4 413
    Par défaut SET Primary Key et identity sur colonne existante
    Bonjour

    Je cherche la syntaxe ALTER pour modifier une colonne existante et y metre l'idendity et l'assigner en primary Key
    J'ai cherché mais franchement des que l'on fait une recherche de syntaxe SQL c'est la Jungle impénétrable !

    Voici le DDL de ma table je souhaiterais que MyKey soit Primary Key et Identity ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    CREATE TABLE [dbo].[Test](
    	[MyKey] [int] NULL,
    	[Name] [varchar](50) NULL
    )
    Par la meme occasion j'ai une autre petite question : je vois que si je demande a SSMS de me generer le script de creation il ajoute une commande ON Primary

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    CREATE TABLE [dbo].[Testu](
    	[MyKey] [int] NULL,
    	[Name] [varchar](50) NULL
    ) ON [PRIMARY]
    Que signifie ce ON PRIMARY ?
    J'ai aussi cherché mais c'est tout aussi peu clair !

    Merci de votre aide

  2. #2
    Membre Expert

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Juin 2012
    Messages
    612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Conseil

    Informations forums :
    Inscription : Juin 2012
    Messages : 612
    Par défaut
    Bonjour,

    Pour ajouter une contrainte PK vous devez faire quelque chose comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ALTER TABLE Test ADD PRIMARY KEY (MyKey);
    Par contre, sauf erreur de ma part l'identity c'est sur SQL Server ; je ne connais pas bien SQL Server mais il me semble qu'on ne peut pas ajouter par la suite l'identity.
    Dans ce cas il vous faudrait créer soit une seconde table, soit une seconde colonne ; copier les données puis supprimer l'ancienne table (ou colonne) et renommer la nouvelle.

    Bonne continuation.

    Cordialement,
    FSiebert

  3. #3
    Membre expérimenté
    Profil pro
    Mangeur de gauffre
    Inscrit en
    Octobre 2007
    Messages
    4 413
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Mangeur de gauffre

    Informations forums :
    Inscription : Octobre 2007
    Messages : 4 413
    Par défaut
    Merci Fsiebert

    Pourtans SSMS parvient a ajouter une Identity et je ne crois pas qui opere toute cette cuisine pour le faire !

  4. #4
    Membre Expert

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Juin 2012
    Messages
    612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Conseil

    Informations forums :
    Inscription : Juin 2012
    Messages : 612
    Par défaut
    Pour ajouter la PK il faut faire l'ALTER que j'ai donné ci-dessous.
    Pour ajouter la propriété IDENTITY à une colonne existante, je crois avoir déjà lu que ce n'est pas possible (je vous laisse vérifier). Dans ce cas la seule solution est de recréer la table. Et pour conserver les données il faut procéder de la façon que j'ai décrite ci-dessous.

    Si SSMS permet d'ajouter l'identity il fait probablement cette opération (ou alors je me trompe et il est possible d'ajouter l'identity plus simplement).

    Bon courage
    FSiebert

  5. #5
    Membre Expert

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Juin 2012
    Messages
    612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Conseil

    Informations forums :
    Inscription : Juin 2012
    Messages : 612
    Par défaut
    Après une brève recherche, je confirme mon propos, je vous laisse consulter cet article : http://blog.sqlauthority.com/2009/05...rty-on-column/

    En espérant avoir pu vous aider

    FSiebert

  6. #6
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Par défaut
    Bonjour,

    Citation Envoyé par Olibara
    Pourtans SSMS parvient a ajouter une Identity et je ne crois pas qui opere toute cette cuisine pour le faire !
    Si si, prenez le Profiler, c'est ce que fait SSMS.
    C'est d'ailleurs ce que montre Pinal Dave (Merci Fsiebert pour le lien)

    @++

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 12/08/2008, 12h20
  2. PRIMARY KEY et FOREIGN KEY sur la même colonne ?
    Par SpecialCharacter dans le forum Outils
    Réponses: 4
    Dernier message: 31/01/2008, 17h35
  3. Ajout incrément auto sur colonne existante
    Par cc055 dans le forum Langage SQL
    Réponses: 1
    Dernier message: 10/08/2007, 11h06
  4. Ajouter en TSQL l'autoincrémentation sur colonne existante
    Par [DreaMs] dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 15/12/2005, 18h13
  5. pb de primary key sur 2 colonnes
    Par new_wave dans le forum Designer
    Réponses: 14
    Dernier message: 25/11/2005, 11h05

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