问题
I have a query that I am running in SQL Server Management Studio (connecting to a SQL Server 2005 database). I want to export the data in CSV format. Not wannabe CSV format, where you just stick a comma between each column, but "real" CSV format, where you put quotes around your strings. This way you can export data that has commas or quotes in it.
All the examples I see limit themselves to the wannabe format. I can't figure out where the option to quote strings is.
If SSMS is truly incapable of this basic feat, are there other tools that will do it easily? I don't want to have to write a C# program every time I need a data dump.
回答1:
In SSMS 2012 there's an option for this, in Tools -> Options -> Query Results -> SQL Server -> Results to Grid, it's called "Quote strings containing list separators when saving .csv results". I don't know how long such an option has existed for, but I'm baffled by two things:
- How come it's not turned on by default
- How come it's an option and not an intrinsic part of the CSV exporting code
It just defies belief that the default behaviour is to have CSV export that's impossible to import properly. I've noticed Excel does the same, I'll have to go see if that's got an option too.
In the mean time, thanks to my colleague who pointed me to this bizarre bit of functionality when I was ranting about how the CSV exporter was completely useless, and this was the best link I'd found about it so I thought I'd put the knowledge here for the benefit of future searchers.
UPDATE
A screenshot below:
回答2:
My normal work-around is to build it into the query:
SELECT '"' + REPLACE(CAST(column AS NVARCHAR(4000)), '"', '""') + '"' AS Header, ... FROM ...
You can build that into a user-defined function, to make it a little easier, but you have to build a separate function for each data type.
回答3:
Different combinations of these settings can bring results in the output that are incorrect or partial data. This is because Microsoft didn't think it was important enough to fix these issues. I'm only explaining what happens with CSV files when sending the results to a file.
To get good results, do the following:
Open new query window (new tab/session) ... if you do not, configuration below is lost and set back to the defaults
Write the query to handle the quote inside the quote, and also wrap all string data types in quotes. Also be aware that different DBMS and programming language grammars accept a different syntax for an escaped double quote (if using this output as input to another system). Some use \"
. Some use ""
. XML uses "
;. Probably a reason Microsoft chose to ignore this functionality, so they didn't have to deal with the arguments.
.. If Escape Sequence of new system is ""
.
SELECT '"' + REPLACE(CAST(column1 AS VARCHAR(MAX)), '"', '""') + '"' FROM table1
.. If Escape Sequence of new system is \"
.
SELECT '"' + REPLACE(CAST(column1 AS VARCHAR(MAX)), '"', '\"') + '"' FROM table1
Configuration:
Query Options > Results > "Include column headers when copying or saving the results" checked
Query Options > Results > "Quote strings containing list separators when saving .csv results" - BROKEN; DO NOT USE!
Query Options > Results > others unchecked
Query Options > Results > Text > comma delimited (setting on top right corner)
Query Options > Results > Text > "Include column headers in the result set" checked
Query Options > Results > Text > others unchecked
Query Options > Results > Text > "Maximum number of characters displayed in each column" - set to max length so strings don't get truncated.
Query > Results To File (this is a toggle between all 3 options)
Execute query (F5)
Prompt for file name of report
Open file to look at results
NOTE: If you need to do this on a regular basis, you're better off just developing a program that will do this for you in .NET or Java, or whatever language you are comfortable with. Otherwise you have a high probability of making a mistake. Then be extremely aware of the syntax of the system you're importing into, before you define your export out of SQL Server.
回答4:
How do you feel about Export to CSV from SSMS via PowerShell? This post describes how to define an external tool in SSMS that sends the currently selected query to a PowerShell script which exports to a CSV.
回答5:
It's sad the option is available in a confusing state, yet not perfectly operational. The following is working at least.
- Choose "Tasks>Export Data" from the DB context menu (does not work at Table level either)
- For Source, choose "Microsoft OLE DB Provider for SQL Server"
- For destination choose "Flat File...", and specify "Format" as delimited and
text qualifier
as double-quote - Select Table or query (I worked with query)
- Finish the wizard
you should be good to go!
回答6:
I know of no way to do this with SSMS alone. I know TOAD (http://www.toadworld.com/) has a CSV option. Not sure if it is an escaped format. If SSIS is an option, you can convert to a format that escapes strings (true CSV), but that is not in SSMS.
If you have to write a C# program, I would consider querying the table and then running the query, as the metadata will clue which need the escape.
回答7:
Usually I use this kind of function:
CREATE FUNCTION [dbo].[toExport]
(
@txt varchar(max)
)
RETURNS varchar(max)
AS
BEGIN
return REPLACE(REPLACE(REPLACE(@txt, ';', ','), CHAR(10), ' '), CHAR(13), ' ');
END
And in select I put it here:
SELECT dbo.toExport( column_name ) AS column_name FROM ....
And in SMSS 2012 simply Right click on a grid and save results as, or copy all grid (ctrl-A) and ctrl-V to Excel.
It's easiest way to manage data in for example MS Excel without problems with columns.
Of course you must click "Quote strings containing list separators when saving .csv results" in Tools -> Options -> Query Results -> Sql Server -> Results to Grid and increase Maximum Characters Retrieved if you need it.
回答8:
Maybe this won't work for your application, but I usually get around this problem by exporting to a tab-delimited format. Don't overlook this simple solution if it applies for you.
回答9:
As all the settings mentioned above didn't fix the CSV my SSMS (SQL Server 2014) generated and exporting a tab-separated file didn't make it any better, a colleague and me made a converter script (Ruby) to convert the SSMS CSV into readable CSV. It keeps encoding, separators and linebreaks of the original file and even does an exact-byte-match validation at the end (it creates a file in the SSMS format from the parsed (!) input file and compares both files).
https://gist.github.com/gr8bit/62202ea89a7e3aff67df2ff080ee8e88
Contact me on github if you encounter errors, please. Cheers!
回答10:
I think the easiest is to open excel and import the data from SQL connection rather than using SSMS export.... I'm using SSMS 2016 and it doesn't have the option "Quote strings containing list separators when saving .csv results" presumably because it doesn't work
Ron
来源:https://stackoverflow.com/questions/6115054/how-to-get-export-output-in-real-csv-format-in-sql-server-management-studio