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 :

Alter table dans procédure stockée


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2
    Par défaut Alter table dans procédure stockée
    Bonjour à tous,

    j'ai un problème dans une procédure stockée : je crée une table temporaire, je fais un bulk insert d'un fichier dans cette table, je modifie la table pour ajouter une colonne, puis je fais des contrôles sur les données.
    L'alter table pour ajouter une colonne fonctionne seulement si il n'y a pas le contrôle de donnée ensuite. Je ne comprends pas pourquoi...

    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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    CREATE PROCEDURE [dbo].ps_tap_import_GLA 
    -- importe les données du fichier du grand livre analytique dans la table après différents contrôles
    -- n'est lancée que s'il y a un fichier à intégrer
    @cheminFichier varchar(100),
    @nomFichier varchar(100)
    AS
    declare @query varchar(2000)
    declare @result int
    begin
     
    -- On créé la table Temporaire de destination
    if exists (select uid from tempdb.dbo.sysobjects where name = '##GL_ANALYTIQUE')
    	drop table ##GL_ANALYTIQUE
     
    CREATE TABLE ##GL_ANALYTIQUE (
    	num_mvt varchar(255) NULL,
    	num_ecriture varchar (255) NULL ,
    	compte_ana_12 varchar (255) NULL ,
    	compte_gene varchar (255) NULL ,
    	code_uc_aff varchar (255) NULL ,
    	code_uc_emet varchar (255) NULL ,
    	debit varchar (255) NULL ,
    	credit varchar (255) NULL ,
    	quantite varchar (255) NULL ,
    	code_journal varchar (255) NULL ,
    	complement_uc varchar (255) NULL ,
    	ref_externe varchar (255) NULL ,
    	exercice_comptable varchar (255) NULL ,
    	mois_comptable varchar (255) NULL ,
    	code_periode varchar (255) NULL ,
    	date_enregistrement varchar (255) NULL ,
    	lib_ecr varchar(255) NULL
    ) 
     
    	set @nomFichier=@cheminFichier+@nomFichier
    -- On insère les données du fichier dans la table temporaire			
    	set @query='bulk insert dbo.##GL_ANALYTIQUE from ''' + @nomFichier + ''''
    	set @query=@query+' with ('
    	set @query=@query+'fieldterminator=''\t'','
    	set @query=@query+'firstrow=2,'
    	set @query=@query+'keepnulls)'
    	print @query
    	execute (@query)
     
    -- On ajoute un champ flag à la table temporaire
    print 'ajout flag à la table'
    ALTER TABLE  dbo.##GL_ANALYTIQUE  ADD flag1 varchar(1) NULL
     
     
    -- On contrôle les lignes
    print 'contrôle des lignes'
    -- longueur de champs 
    -- si l'update suivant est enlevé, la table est modifiée, tout va bien
    -- sinon, la table n'est pas modifié, et la colonne flag1 n'existe pas !!!!
    update dbo.##GL_ANALYTIQUE 
    set flag1='1'
    where len(num_mvt) > 9
    or len(compte_gene) > 8
    or len(code_journal) > 3
    or len(complement_uc) > 5
    or len(ref_externe) > 15
    or len(code_periode) > 1
    or len(lib_ecr)>30
    or len(num_ecriture)>9
     
     
    end
    GO
    Merci d'avance pour votre aide !

  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
    L'ALTER devrait fonctionner à tous les coups ! Quel est le msg d'erreur lorsque cela ne marche pas ?
    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
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2
    Par défaut
    merci pour votre réponse.
    Il n'y a pas de message d'erreur au niveau de l'alter table.
    C'est juste qu'au moment de faire l'update, il ne trouve pas la colonne flag1 :

    ajout flag à la table
    Serveur : Msg 207, Niveau 16, État 1, Procédure ps_tap_import_GLA, Ligne 54
    Invalid column name 'flag1'.

    et effectivement, quand je vérifie, la colonne flag1 n'a pas été ajoutée...

  4. #4
    Membre habitué
    Inscrit en
    Février 2004
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Février 2004
    Messages : 11
    Par défaut
    je ne sais pas si c'est tres orthodoxe, mais en rajoutant un GO
    apres l'ADD flag1 ca peux marcher

  5. #5
    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
    Citation Envoyé par RSBMW
    je ne sais pas si c'est tres orthodoxe, mais en rajoutant un GO
    apres l'ADD flag1 ca peux marcher
    Un go au milieu d'une SP
    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 !

Discussions similaires

  1. Création table externe dans procédure stockée
    Par chouchouilloux dans le forum PL/SQL
    Réponses: 6
    Dernier message: 20/09/2013, 18h39
  2. [ASE] Alter table dans une procédure stockée
    Par malignois dans le forum Adaptive Server Enterprise
    Réponses: 2
    Dernier message: 01/10/2009, 11h20
  3. Réponses: 2
    Dernier message: 03/03/2006, 13h41
  4. Problème d'alter table dans une procédure stockée
    Par Oluha dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 16/03/2005, 09h19
  5. SQL dans Procédure stockée
    Par julure dans le forum Oracle
    Réponses: 13
    Dernier message: 02/11/2004, 16h57

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