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 :

comment supprimer un clé primaire d'un tableau avec une requte SQL


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Inscrit en
    Octobre 2006
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 2
    Par défaut comment supprimer un clé primaire d'un tableau avec une requte SQL
    bonjour je veux supprimer un clé primaire d'un tableau j'arrive pas comment faire ????????????
    je vous demande de m'aider
    merci d'avance

  2. #2
    Rédacteur/Modérateur

    Avatar de Fabien Celaia
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Octobre 2002
    Messages
    4 228
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Service public

    Informations forums :
    Inscription : Octobre 2002
    Messages : 4 228
    Billets dans le blog
    25
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    alter table .... drop constraint ...
    Sr DBA Oracle / MS-SQL / MySQL / Postgresql / SAP-Sybase / Informix / DB2

    N'oublie pas de consulter mes articles, mon blog, les cours et les FAQ SGBD

    Attention : pas de réponse technique par MP : pensez aux autres, passez par les forums !

  3. #3
    Membre confirmé Avatar de mouloudéen
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    193
    Détails du profil
    Informations personnelles :
    Localisation : Algérie

    Informations forums :
    Inscription : Mai 2005
    Messages : 193
    Par défaut
    Citation Envoyé par fadace Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    alter table .... drop constraint ...
    Bonjour,

    J'ai essayé la commande et ça marche très bien lorsque je connais le nom de la clé primaire.

    Seulement, maintenant je veux créer un Script dynamique qui permet de supprimer la clé primaire sans connaître son nom.

    Je sais qu'on peut récupérer le nom de la clé en utilisant:
    SELECT CONSTRAINT_NAME FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS WHERE TABLE_NAME = 'Nom_Table'
    Donc j'ai essayé la commande :

    ALTER TABLE [products]
    DROP CONSTRAINT (SELECT CONSTRAINT_NAME FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS WHERE TABLE_NAME = 'Nom_Table')
    Malheureusement, elle me sorte une erreur.

    J'aimerai bien que vous m'aider pour trouver une solution.


    Cordialement

  4. #4
    Membre éprouvé
    Profil pro
    Inscrit en
    Février 2006
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Février 2006
    Messages : 126
    Par défaut
    Bonjour,

    Tu peux utiliser du SQL dynamique du genre :

    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
    DECLARE @ma_table VARCHAR(250)
    SET @ma_table = 'nom_de_la_table'
     
    DECLARE @ma_contrainte VARCHAR(250)
    DECLARE @mon_instruction NVARCHAR(1000)
     
    SELECT @ma_contrainte = CONSTRAINT_NAME
    FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS
    WHERE TABLE_NAME = @ma_table
    	AND CONSTRAINT_type ='PRIMARY KEY'
     
     
    SET @mon_instruction = 'ALTER TABLE '+ @ma_table +
    +' DROP CONSTRAINT ' + @ma_contrainte
     
    EXECUTE sp_executesql @mon_instruction

  5. #5
    Expert confirmé

    Homme Profil pro
    consultant développeur
    Inscrit en
    Mai 2005
    Messages
    3 039
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : consultant développeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 039
    Par défaut
    Bonjour,

    En en faisant une requete parametree :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    DECLARE @TblName1 VARCHAR(50),@SQLString VARCHAR(200), @ParamPK VARCHAR(50)
     
    SET @TblName1 = 'Products'			-- nom court de la table
     
    SELECT @ParamPK=CONSTRAINT_NAME FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS WHERE TABLE_NAME = @TblName1
    print @ParamPK
     
    set @SQLString= 'ALTER TABLE NomTonSchema.' + @TblName1 + ' DROP CONSTRAINT ' + @ParamPK 
    print @SQLString
     
    EXECUTE(@SQLString)
    Espérant aider

    Edit : Désolé, Erwan, je n'avais pas actualisé avant de poser ma réponse.
    Mais abondance de biens ne nuit pas ...

  6. #6
    Membre confirmé Avatar de mouloudéen
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    193
    Détails du profil
    Informations personnelles :
    Localisation : Algérie

    Informations forums :
    Inscription : Mai 2005
    Messages : 193
    Par défaut
    @ micniv & Erwan1978 : Merci pour vos réponse. Ce n'est qu'hier que j'ai pu tester vos solutions.

    Merci encore pour la solution

Discussions similaires

  1. Comment faire boucler un job sur le résultat d'une requête SQL ?
    Par galadorn dans le forum Développement de jobs
    Réponses: 1
    Dernier message: 27/04/2011, 11h42
  2. Envoyer par GET un tableau d'une requête SQL
    Par xess91 dans le forum Langage
    Réponses: 17
    Dernier message: 21/05/2010, 10h08
  3. Réponses: 4
    Dernier message: 11/06/2009, 16h03
  4. [SQL] Sortie tableau d'une requête sql
    Par wac06 dans le forum PHP & Base de données
    Réponses: 12
    Dernier message: 26/02/2008, 13h14
  5. [MySQL] Remplir un tableau avec une requête
    Par comme de bien entendu dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 12/06/2007, 11h27

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