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 :

sql server 2000 et bulk nsert


Sujet :

MS SQL Server

  1. #1
    Membre expert

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2007
    Messages
    3 494
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 494
    Points : 3 122
    Points
    3 122
    Par défaut sql server 2000 et bulk nsert
    Bonjour,

    Dans un procédure stockée, je fais un insert d'un fichier csv dans une table.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    BULK INSERT #temp_import_srf FROM 'C:\truc.csv'
    WITH (
       CODEPAGE        = 'ACP',
       FIELDTERMINATOR = ';', 
       ROWTERMINATOR   = '\n' 
    )
    Ca fonctionne parfaitement.

    Puis j'ai voulu utiliser un paramètre de ma procédure pour remplacer le nom de fichier.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    ALTER PROCEDURE [dbo].[import_srf] 
        @fichier_source VARCHAR(255)
    AS
    BEGIN
    ...
     
    BULK INSERT #temp_import_srf FROM @fichier_source
    WITH (
       CODEPAGE        = 'ACP',
       FIELDTERMINATOR = ';', 
       ROWTERMINATOR   = '\n' 
    )
    Et là, ça ne fonctionne plus.

    Msg*170, Niveau*15, État*1, Procédure*import_srf, Ligne*28
    Ligne 28 : syntaxe incorrecte vers '@fichier_source'.
    Est-il impossible d'utiliser une variable dans ce cas précis ?

    Papy !

  2. #2
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 10
    Points : 14
    Points
    14
    Par défaut
    Bonjour,

    De manière générale, SQL Server 2000 ne permettait pas de supporter les variables dans un grand nombre d'instructions. Cela a été étendu dans SQL Server 2005.

    Peux-être la solution réside dans du code SQL Dynamique ?

    Bonne journée

  3. #3
    Membre expert

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2007
    Messages
    3 494
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 494
    Points : 3 122
    Points
    3 122
    Par défaut
    J'ai effectivement fini par trouver que dans ce cas, l'utilisation d'une variable est interdite. Au moins pour cette version de sql server.

    J'ai donc créé une chaine de caractères en y insérant le nom du fichier récupéré dans la paramètre et utilisé EXEC pour exécuter le code et ça a fonctionné sans problème.

    Merci pour le coup de main

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

Discussions similaires

  1. problème avec bulk insert sql server 2000
    Par siyassine dans le forum Administration
    Réponses: 1
    Dernier message: 25/08/2010, 08h31
  2. Certification 70-228 sql server 2000
    Par Cotentin dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 20/11/2003, 09h01
  3. Débutant : SQL Server 2000
    Par bd0606 dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 27/10/2003, 11h33
  4. Migration de MS SQL 7 vers MS SQL server 2000
    Par jfphan dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 15/10/2003, 11h24
  5. problème de float sur SQL server 2000.
    Par fidji dans le forum MS SQL Server
    Réponses: 9
    Dernier message: 24/07/2003, 14h15

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