Zugriff auf Dateisystem mit SQL Server 2012
Hallo liebe Admins,
ich muss via SQL Server .csv-Dateien aus einem Verzeichnis einlesen.
Via Import Assi geht das ja einfach, allerdings mit einer fest angegebenen Datei
Der Zugriff soll aber dynamisch gestaltet sein, d.h. SQL soll immer die aktuellste Datei im Verzeichnis nehmen und importieren.
Die Dateien sind mit Datum im Dateinamen versehen (z.B.: 20130613_xxxx.csv).
Wie bekomme ich es hin, dass ich z.B via T-SQL das Datum der Dateierstellung herausfinden kann oder eine dynamische Abfrage generieren kann die immer die letzte Datei aufgrund des Dateinamens für den Import nimmt?
Vielen Dank für Eure Hilfe.
Gruss DerO
Zusatz 18.06:
ich denke ich habe es fast gelöst...
folgender Code funzt fast, allerdings weiß ich nicht wie ich die Verknüpfung beim bulk insert hinbekomme.
declare @dateidatum nvarchar(50);
declare @dateiname nvarchar(50);
set @dateidatum = format(getdate(),'yyyyMMdd');
set @dateiname = @dateidatum + '-xxx.csv';
--select @dateiname as Dateiname
bulk insert datenbankname.dbo.tabellenname from '\\server\verzeichnnis\unterverzeichnis\' + @dateiname
with
(
FIELDTERMINATOR = ';' ,
ROWTERMINATOR = '\n' )
Nur mag er die Verknüpfung + @dateiname nicht!
Die auskommentierte Select bringt mir den richtigen Dateinamen.
Könnte mir bitte nochmal ein SQL-Spezi helfen?
Vielen Dank.
Gruss O.
ich muss via SQL Server .csv-Dateien aus einem Verzeichnis einlesen.
Via Import Assi geht das ja einfach, allerdings mit einer fest angegebenen Datei
Der Zugriff soll aber dynamisch gestaltet sein, d.h. SQL soll immer die aktuellste Datei im Verzeichnis nehmen und importieren.
Die Dateien sind mit Datum im Dateinamen versehen (z.B.: 20130613_xxxx.csv).
Wie bekomme ich es hin, dass ich z.B via T-SQL das Datum der Dateierstellung herausfinden kann oder eine dynamische Abfrage generieren kann die immer die letzte Datei aufgrund des Dateinamens für den Import nimmt?
Vielen Dank für Eure Hilfe.
Gruss DerO
Zusatz 18.06:
ich denke ich habe es fast gelöst...
folgender Code funzt fast, allerdings weiß ich nicht wie ich die Verknüpfung beim bulk insert hinbekomme.
declare @dateidatum nvarchar(50);
declare @dateiname nvarchar(50);
set @dateidatum = format(getdate(),'yyyyMMdd');
set @dateiname = @dateidatum + '-xxx.csv';
--select @dateiname as Dateiname
bulk insert datenbankname.dbo.tabellenname from '\\server\verzeichnnis\unterverzeichnis\' + @dateiname
with
(
FIELDTERMINATOR = ';' ,
ROWTERMINATOR = '\n' )
Nur mag er die Verknüpfung + @dateiname nicht!
Die auskommentierte Select bringt mir den richtigen Dateinamen.
Könnte mir bitte nochmal ein SQL-Spezi helfen?
Vielen Dank.
Gruss O.
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 208162
Url: https://administrator.de/contentid/208162
Ausgedruckt am: 05.11.2024 um 06:11 Uhr
5 Kommentare
Neuester Kommentar
Hallo O
der MSSQL 2012 hat doch ein Powershellmodul, damit sollte es klappen.
die Datei kannst du mit nen
oder
ermitteln.
Da ich hier gerade kein MSSQL habe kann ich dir nur den Link anbieten
http://blogs.technet.com/b/heyscriptingguy/archive/2011/11/28/four-easy ...
Der Torsten wars
der MSSQL 2012 hat doch ein Powershellmodul, damit sollte es klappen.
die Datei kannst du mit nen
#neuste beschriebene Datei ermitteln
get-childitem -Path DeinPfad | sort -Descending LastwriteTime | select -first 1
#neuste Datei anhand von Timestamp in Dateiname ermitteln
get-childitem -Path DeinPfad | sort -Descending Name | select -first 1
Da ich hier gerade kein MSSQL habe kann ich dir nur den Link anbieten
http://blogs.technet.com/b/heyscriptingguy/archive/2011/11/28/four-easy ...
Der Torsten wars