MSSQL Dump Trennzeichen einfügen
Nabend,
ich habe auf einem Server ein MS SQL Express 2008 R2 Datenbank laufen.
Aufgrund der Express-Version kann ich dort die "maintenance plan" Funktion nicht nutzen, also habe ich mir eine Alternativ per Batch ausgedacht, wobei sich nun folgendes Problem ergibt.
Zuerst mal kurz die Batch Datei:
Ich weis, das Passwort steht in der Batchdatei, aufgrund der express Version fällt mir keine andere Lösung ein.
Das Script soll mir also alle Datensätze ausgeben, bei denen der Wert complete NULL ist.
Als Export bekomme ich ca. so was
Das Problem ist nun, zwischen den ganzen Datensätzen sind lauter Leerzeichen, wodurch ich die Datei später mit PHP auf einem andern Server schlecht bearbeiten kann.
Gibt es eine Möglichkeit, entweder per Batch, oder auf nem anderen Weg, ein Export ähnl. oben so zu machen, dass ich nur Daten in folgenden Muster habe:
Diese kann ich dann später mit dem PHP explode viel besser weiter verarbeiten.
Gruß
8digit
ich habe auf einem Server ein MS SQL Express 2008 R2 Datenbank laufen.
Aufgrund der Express-Version kann ich dort die "maintenance plan" Funktion nicht nutzen, also habe ich mir eine Alternativ per Batch ausgedacht, wobei sich nun folgendes Problem ergibt.
Zuerst mal kurz die Batch Datei:
echo SELECT [ID]>export_sql_script.sql
echo ,[Name]>>export_sql_script.sql
echo FROM [MS_SERVER_01].[Personal].[Web]>>export_sql_script.sql
echo WHERE complete IS NULL>>export_sql_script.sql
echo GO>>export_sql_script.sql
sqlcmd -S %sqlserver% -i export_sql_script.sql -U %benutzername% -P %passwort% > export.txt
Das Script soll mir also alle Datensätze ausgeben, bei denen der Wert complete NULL ist.
Als Export bekomme ich ca. so was
ID Name
23 Mustermann
53 Mannmuster
Das Problem ist nun, zwischen den ganzen Datensätzen sind lauter Leerzeichen, wodurch ich die Datei später mit PHP auf einem andern Server schlecht bearbeiten kann.
Gibt es eine Möglichkeit, entweder per Batch, oder auf nem anderen Weg, ein Export ähnl. oben so zu machen, dass ich nur Daten in folgenden Muster habe:
23;Mustermann
53;Mannmuster
Diese kann ich dann später mit dem PHP explode viel besser weiter verarbeiten.
Gruß
8digit
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 235051
Url: https://administrator.de/contentid/235051
Ausgedruckt am: 23.11.2024 um 11:11 Uhr
6 Kommentare
Neuester Kommentar
Moin 8digit,
dir ist aber schon bekannt, dass du vom MSSQLServer aus auch direkt .csv-Format exportieren kannst?
Statt
wäre es dann
Mit deiner Syntax wäre es dann:
Grüße
Biber
dir ist aber schon bekannt, dass du vom MSSQLServer aus auch direkt .csv-Format exportieren kannst?
Statt
sqlcmd -S %sqlserver% -i export_sql_script.sql -U %benutzername% -P %passwort% > export.txt
wäre es dann
sqlcmd -S %sqlserver% -s, -U %benutzername% -P %passwort% -W -Q "SELECT [ID], [Name] FROM [Personal].[Web] where complete is null" > export.txt
-s, Definiert das Komma als Spaltendelimiter "-s;" wäre entsprechend Semikolon.
-W Entferne führende Leerzeichen
-Q "SELECT .... FROM ..." Ich habe die Query hier direkt angegeben, geht natürlich auch über deinen Quell-SQL-Weg. Den Servernamen habe ich rausgelassen - du bist auf einem Server angemeldet mit Username und Passwort.
Mit deiner Syntax wäre es dann:
sqlcmd -S %sqlserver% -s, -U %benutzername% -P %passwort% -W -i export_sql_script.sql > export.txt
Grüße
Biber