begin process at 2012 02 04 17:45:00
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Procédure

 > SQL LECTURE IMPORT DE FICHIER TEXTE

SQL LECTURE IMPORT DE FICHIER TEXTE


 Information sur la source

Note :
8 / 10 - par 2 personnes
8,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
Catégorie :Procédure Classé sous :fichier, texte, csv, import, lecture Niveau :Initié Date de création :29/07/2008 Date de mise à jour :29/07/2008 12:54:47 Vu :25 144

Auteur : PHILIPPO

Ecrire un message privé
Site perso
Commentaire sur cette source (6)
Ajouter un commentaire et/ou une note

 Description

Cette procédure permet le lire fichier texte comme un simple SELECT * sur une table.

Pour faire simple j'ai mis tous les champs en Nvarchar(Max)

Source

  • CREATE Procedure dbo.Read_File(@File VarChar(495),@Separator Char(1),@FirstLineColumn Bit)
  • AS
  • BEGIN
  • Declare @Txt Nvarchar(max),@Req VarChar(max),@Res Nvarchar(Max)
  • -------------------------------------
  • --Lecture du fichier Texte avec Dos--
  • -------------------------------------
  • CREATE TABLE ##TB(Valeur nvarchar(Max))
  • Set @Req='BULK INSERT ##TB FROM ''' + @File + ''' WITH(FIRSTROW= 1,LASTROW=1,ROWTERMINATOR = ''' + CHAR(10) + ''')'
  • EXEC(@Req)
  • ------------------------------------------
  • --Création de la table temporaire ##Temp--
  • ------------------------------------------
  • SET @Txt=(SELECT TOP 1 Valeur FROM ##TB) + @Separator
  • DROP TABLE ##TB
  • IF @FirstLineColumn=0
  • BEGIN
  • DECLARE @Nb INT
  • Set @Nb=0
  • WHILE CHARINDEX(@Separator,@Txt)>0
  • BEGIN
  • SET @Res=ISNULL(@Res,'') + '[Column' + convert(Nvarchar,@NB) + '],'
  • SET @Txt=SUBSTRING(@Txt,CHARINDEX(@Separator,@Txt)+1,LEN(@Txt)- CHARINDEX(@Separator,@Txt))
  • SET @Nb=@Nb+1
  • END
  • SET @Res=LEFT(@Res,LEN(@Res)-1)+')'
  • END
  • ELSE
  • BEGIN
  • SET @Res='[' + REPLACE(@Txt,@Separator,'],[')
  • SET @Res=LEFT(@Res,LEN(@Res)-2)+')'
  • END
  • SET @Req='CREATE TABLE ##Temp (' + REPLACE(@Res,']','] NVarChar(Max)')
  • EXEC(@Req)
  • ---------------------------------
  • --Import de données dans ##Temp--
  • ---------------------------------
  • SET @REQ='BULK INSERT ##TEMP FROM ''' + @File + ''' WITH(FIELDTERMINATOR = ''' + @Separator + ''' , FIRSTROW= ' + CONVERT(NVARCHAR, CONVERT(INT,@FirstLineColumn)+ 1) +', ROWTERMINATOR = ''' + CHAR(10) + ''')'
  • EXEC(@REQ)
  • ------------------------------------
  • --Lecture et suppression de ##Temp--
  • ------------------------------------
  • SELECT * FROM ##Temp
  • DROP TABLE ##Temp
  • END
CREATE Procedure dbo.Read_File(@File VarChar(495),@Separator Char(1),@FirstLineColumn Bit)
AS
BEGIN
	Declare @Txt Nvarchar(max),@Req VarChar(max),@Res Nvarchar(Max)
	
	-------------------------------------
	--Lecture du fichier Texte avec Dos--
	-------------------------------------
	CREATE TABLE ##TB(Valeur nvarchar(Max))
	Set @Req='BULK INSERT ##TB FROM ''' +  @File + ''' WITH(FIRSTROW= 1,LASTROW=1,ROWTERMINATOR = ''' + CHAR(10) + ''')'
	EXEC(@Req)

	------------------------------------------
	--Création de la table temporaire ##Temp--
	------------------------------------------
	SET @Txt=(SELECT TOP 1 Valeur FROM ##TB) + @Separator	
	DROP TABLE ##TB

	IF @FirstLineColumn=0
	BEGIN
		DECLARE @Nb INT
		Set @Nb=0
		WHILE CHARINDEX(@Separator,@Txt)>0
		BEGIN
			SET @Res=ISNULL(@Res,'') + '[Column' + convert(Nvarchar,@NB) + '],'
			
			SET @Txt=SUBSTRING(@Txt,CHARINDEX(@Separator,@Txt)+1,LEN(@Txt)- CHARINDEX(@Separator,@Txt))

			SET @Nb=@Nb+1
		END
		SET @Res=LEFT(@Res,LEN(@Res)-1)+')'
	END
	ELSE
	BEGIN
		SET @Res='[' + REPLACE(@Txt,@Separator,'],[')
		SET @Res=LEFT(@Res,LEN(@Res)-2)+')'
	END
	
	SET @Req='CREATE TABLE ##Temp (' + REPLACE(@Res,']','] NVarChar(Max)') 

	EXEC(@Req)
	---------------------------------
	--Import de données dans ##Temp--
	---------------------------------
	SET @REQ='BULK INSERT ##TEMP FROM ''' +  @File + ''' WITH(FIELDTERMINATOR = ''' + @Separator + ''' , FIRSTROW= ' + CONVERT(NVARCHAR, CONVERT(INT,@FirstLineColumn)+ 1) +', ROWTERMINATOR = ''' + CHAR(10) + ''')'

	EXEC(@REQ)

	------------------------------------
	--Lecture et suppression de ##Temp--
	------------------------------------
	SELECT * FROM ##Temp

	DROP TABLE ##Temp
END

 Conclusion

Bien pratique.


 Historique

29 juillet 2008 12:54:47 :
Au lieu d'utiliser xp_cmdshell j'ai utiliser bulk plus performant

 Sources du même auteur

DÉFRAGMENTATION D'INDEX SQL 2000

 Sources de la même categorie

IMPORTATION DE FICHIER TEXT (CSV) RAPIDEMENT par vladam
Source avec une capture T-SQL - SPLIT SANS TABLE TEMPORAIRE par TheOnlyMaX
Source avec Zip (SQL SERVER) REQUÊTE POUR RECHERCHER UN {GUID} DANS TOUS LES... par lassaad83
[ORACLE]DÉTERMINER LA DATE DU PREMIER JOUR D'UNE SEMAINE PAR... par Bouillou2
T-SQL - PROCÉDURE - STOCKÉE - PLACER DANS UNE TABLE LE RÉSUL... par zavier666

 Sources en rapport avec celle ci

IMPORTATION DE FICHIER TEXT (CSV) RAPIDEMENT par vladam
SQL SERVER - OBTENIR LES VALEURS CORRESPONDANT A DES UNICODE par fabrice69
Source avec Zip Source avec une capture SQL SERVER - PROCEDURE D'EDITION D'UN FICHIER PLAT (EXPORT C... par FENETRES
SQL SERVER - MODIFIER LA CROISSANCE DES FICHIERS DE BASE DE ... par fabrice69
SQL SERVER - COMMENT OBTENIR L'EXTENSION D'UN FICHIER DEPUIS... par fabrice69

Commentaires et avis

Commentaire de nicomilville le 01/08/2008 19:15:53 10/10

Salut,

Pas mal ta source !

Connais tu un site ou il y est un tuto sur la création de procédures ?

a++

Commentaire de FENETRES le 23/09/2008 18:22:10

Pour une information à la source voir à l'adresse ci-dessous :

http://msdn.microsoft.com/fr-fr/library/ms188365.aspx

Commentaire de FENETRES le 24/09/2008 11:29:07 6/10

Pour mériter une telle note, il faudrait :
   - ajouter une transaction,
   - ajouter une instruction TRY...CATCH,
   - gérer les caractères accentués,
   - préciser que BULK INSERT, pour optimiser les performances, n'utilise pas les logs transactionnels.

Commentaire de lauamine le 11/05/2009 12:37:11

sql soit transformé au fichier texte

je veux le code en java , en fait je réalise un générateur de données :
Protoype 1 : Création d'une base de données ayant des tables et attributs indépendants en fichier SQL ;

Protoype 2 : Géneration de la base de données avec des tables indépendantes et  des contraintes sur les valeurs des attributs ;

Prototype 3 : Géneration de la base de données dans un certain ordre tenant compte de la dépendance, par exemple il faut génerer une table « Commande » qui fait référence a une table « Client » à travers un attribut « Client
j'ai besoin de vous aides
merci de votre attention

Commentaire de Krayz le 07/12/2009 23:07:08

Gros Merci

Commentaire de karimmassi le 12/07/2011 00:14:01

bon source mais mal documenté.

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

Lecture fichier texte format personnel [ par bluedemon ] Bonjour. Voila, je souhaiterai créer un job sous sql server qui permettrait de lire un fichier texte, dans un répertoire donné, ligne par ligne et d'e Import fichier XML dans SQL SERVER 2000 [ par crn_c21 ] Bonjour,Je débute en SQL et XMLJ'ai un fichier XMLJe voudrais l'importer dans SQLComment faire ?Merci rediriger le résultat d'une requête SQL vers un fichier texte [ par gabiset ] Bonjour,Je fais une requête SQL en ligne de commande DOS et j'aimerais que le résultat de ma requête soit enregistré dans un fichier texte car il est Lire fichier texte dans procedure stockée [ par laurent57150 ] Bonjour,Comme indiqué dans le sujet, je voudrais lire un fichier depuis une procedure afin de réaliser un ceratin nombre d'operation dessus et de l'in Import fichier txt : accents [ par greglover ] Bonjour, J'ai ajouté une fonctionnalité à mon programme java permettant de faire une backup de la bdd dans un fichier .sql Lorsque je teste l'import, Import fichier CSV dans Oracle 9i sous Linux RHEL3 [ par Lucinda000 ] Bonjour à tous,Voilà. J'aimerai importer des fichiers csv sous Oracle 9i qui a déjà une base de données.J'ai bien compris que je devais utiliser sqlld Validation de fichier csv dans un DTS [ par samoht ] Bonjour,J'ai un DTS sur sql2005 qui importe les données d'un fichier CSV stocké sur le lecteur D du serveur. Jusqu'ici, l'importation se passe correct Import de données depuis un fichier Excel [ par BUZZ2K ] Bonjour,Afin d'allimenter ma base de donnees (une seule table en fait), je dispose d'un fichiers excel contenant les informations voulues.J'aurai aime LOAD DATA LOCAL INFILE insert que certaines colonnes [ par ericsandrine ] bonjour j'ai un fichier csv avec 10 colonnes et ma table n'a que 3 colonnes peut on faire un LOAD DATA LOCAL INFILE en ne récupérant que certaines Génerer un fichier CSV en SQL SERVER 2000. [ par mdab ] mdab Bonjour, J'ai besion de génerer un fichier csv en sql server 2000. Est ce qu'il ya une fonction qui permet de retourner ce resultat.(l'equivant


Nos sponsors


Sondage...

CalendriCode

Février 2012
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
272829    

Consulter la suite du CalendriCode

Photothèque

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,359 sec (4)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales