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

Sybase Discussion :

Procedure de suppressions des champs d'une table


Sujet :

Sybase

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Inscrit en
    Mars 2009
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 1
    Par défaut Procedure de suppressions des champs d'une table
    Bonjour,

    Je suis un débutant en informatique et je suis actuellement en stage, dans ce cadre je gères une base données avec Sybase+Aqua Data Studio(interface de programmation sql)

    Je travaille sur de grosses tables (contenant une centaine de champs), afin de pouvoir supprimer des champs rapidement je me suis mis en tête de créer une procedure qui serait prévue à cette effet.

    En voici le squelette :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    create proc proc_delete_fields (@table varchar(100)='' , 
                                              @fields varchar(200) = 'col1,col2,col3,col4') as 
    begin
    declare @col varchar(10),
        @delim varchar(10) 
        set @col = (select SubString(@fields,1, 4, @delim))
        set @delim = ', '
     
    for .......
        execute ('alter table '||@table||' drop '||@col||' ')
     
    end
    En entrant le nom de la table et la liste des champs concernés separés par une virgule.
    Je souhaiterai mettre en place une boucle permettant de les supprimers.
    Mon probleme est que je ne vois pas comment extraire des colonnes en specifiant qu'elles sont séparées par des ',' dans ma variable @fields.

    Si quelqu'un pouvait me donner un coup de pouce, Ce serait aimable de sa part !!

    A+

  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
    1
    2
    3
    4
    5
    6
    7
    proc_delete_fields (@TABLE varchar(30)='', 
                              @FIELDS varchar(200) ='col1,col2,col3,col4') 
    AS
    declare @sql
    select @sql='alter table '+@TABLE+' DROP COLUMN '+@FIELDS
    execute (@sql)
    END
    ... ben oui, selon la syntaxe du DROP COLUMN, on peux spécifier les colonnes en un coup !
    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 !

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

Discussions similaires

  1. [AC-2007] Suppression des champs d'une table
    Par Cyril dLL dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 24/11/2013, 08h48
  2. Suppression des champs d'une table
    Par jackvpt dans le forum Bases de données
    Réponses: 11
    Dernier message: 02/01/2011, 17h43
  3. Ajouter des champ dans une table avec une procedure sp
    Par Abdou1 dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 26/07/2006, 18h32
  4. nom des champs d'une table
    Par K-ZimiR dans le forum Requêtes
    Réponses: 6
    Dernier message: 22/04/2004, 14h21
  5. Ordre des champs dans une table
    Par patapetz dans le forum Outils
    Réponses: 5
    Dernier message: 30/07/2003, 06h53

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