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

Développement SQL Server Discussion :

[2008R2_x64] Import fichier CSV Microsoft.ACE.OLEDB.12.0


Sujet :

Développement SQL Server

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2002
    Messages
    219
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2002
    Messages : 219
    Points : 121
    Points
    121
    Par défaut [2008R2_x64] Import fichier CSV Microsoft.ACE.OLEDB.12.0
    Bonjour,

    Après avoir passer des heures avec une erreur :

    Error - OLE DB Provider 'Microsoft.ACE.OLEDB.12.0' for Linked Server '(Null)' Returned Message 'Unspecified Error'

    J'ai enfin réussi a lire mon fichier CSV.

    Mon problème c'est que le délimiteur ; n'est pas pris en charge.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT * FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0','Text;
    Database=c:\toto\;ColNameHeader=False;
    Format=CSVDelimited;
    MaxScanRows=0;
    CharacterSet=OEM;
    ColNameHeader=True;
    Format=Delimited(;)','SELECT * FROM toto.csv')
    Par contre si j'ajoute un fichier shema.ini
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    [schema.ini]
    ColNameHeader=False
    Format=CSVDelimited
    MaxScanRows=0
    CharacterSet=OEM
    ColNameHeader=True
    Format=Delimited(;)
    [toto.csv]
    ColNameHeader=True
    Format=Delimited(;)
    Cela fonctionne.

    Est il possible de lire un fichier CSV (délimiteur ; ) sans le shema.ini ?

    Merci pour votre aide

    PS: Si cela interesse les modérateurs, je peux faire un poste sur la mise en oeuvre de : Error - OLE DB Provider 'Microsoft.ACE.OLEDB.12.0' for Linked Server '(Null)' Returned Message 'Unspecified Error'

  2. #2
    Membre confirmé
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Novembre 2010
    Messages
    304
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Consultant en Business Intelligence
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2010
    Messages : 304
    Points : 579
    Points
    579
    Par défaut
    Ce serait pas du au fait que ton serveur est en options régionales US (où le délimiteur des fichiers CSV est la virgule) ?

    Par contre, c'est pas mieux de faire un openrowset (bulk... dans le cas d'un fichier texte?

  3. #3
    Membre actif
    Inscrit en
    Juin 2006
    Messages
    229
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 229
    Points : 266
    Points
    266
    Par défaut
    D'accord aussi pour dire que c'est beaucoup mieux de faire un BULK INSERT pour lire un fichier texte. C'est plus performant en plus.
    Et pas besoin de fichier schema.ini. Ex :

    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
    CREATE TABLE #T_TEMP
    (
    	COL1 VARCHAR(MAX)
    	,COL2 VARCHAR(MAX)
    )
     
    BULK INSERT #T_TEMP
    FROM 'C:\temp\toto.csv'
    WITH 
    ( 
    	FIRSTROW = 2
    	,FIELDTERMINATOR = ';'
    	,CODEPAGE = 'RAW'
    	,TABLOCK
    )
     
    SELECT * FROM #T_TEMP
     
    DROP TABLE #T_TEMP
    @+

Discussions similaires

  1. Import fichier CSV
    Par oki972 dans le forum SQLite
    Réponses: 5
    Dernier message: 08/10/2007, 20h58
  2. [Pb Importation fichier CSV]
    Par Jeremie_Vi dans le forum Access
    Réponses: 2
    Dernier message: 04/05/2007, 06h54
  3. Importation fichier CSV Excel
    Par @lex(is) dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 22/06/2006, 02h16
  4. Update de plusieurs tables, import fichier csv sql loader
    Par fusuke dans le forum SQL*Loader
    Réponses: 2
    Dernier message: 18/05/2006, 15h08
  5. Réponses: 9
    Dernier message: 31/01/2006, 22h42

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