🚀 Try Zilliz Cloud, the fully managed Milvus, for free—experience 10x faster performance! Try Now>>

Milvus
Zilliz

How do you export query results to a file in SQL?

To export query results to a file in SQL, the method depends on the database system you’re using. Most systems provide a direct SQL command or a utility to handle this. The general approach involves running a query and specifying a file path where the results should be saved. Common formats for exports include CSV, TXT, or Excel files. Permissions and file system access are critical—your database user must have write privileges to the target directory. Below are specific methods for popular databases, followed by important considerations.

In MySQL, use INTO OUTFILE after your SELECT statement. For example:

SELECT * FROM employees INTO OUTFILE '/tmp/employees.csv' 
FIELDS TERMINATED BY ',' ENCLOSED BY '"' LINES TERMINATED BY '\n';

This creates a CSV file with commas as separators. The server must have write access to /tmp/. PostgreSQL uses the COPY command:

COPY (SELECT * FROM employees) TO '/path/employees.csv' WITH CSV HEADER;

For local exports without superuser privileges, use \copy in the psql client. SQL Server offers the bcp utility or SSMS’s export wizard. Using bcp:

bcp "SELECT * FROM Employees" queryout "C:\data\employees.csv" -c -t, -S server_name -T

The -T uses trusted authentication. SQLite uses .mode and .output in its command-line shell:

.mode csv
.output employees.csv
SELECT * FROM employees;
.output stdout

Key considerations include security (avoid exposing sensitive files), formatting (use delimiters like commas or tabs), and headers (include column names with HEADER in PostgreSQL or -h in bcp). Some systems, like Oracle, require tools like SQL*Plus (SPOOL employees.txt; SELECT * FROM employees; SPOOL OFF;). GUIs like MySQL Workbench or DBeaver also provide export buttons for quick saves. Always validate file paths and test permissions—errors like “Permission denied” or “File exists” are common if paths are incorrect or overwrites are blocked. Choose the method that aligns with your workflow and toolchain.

Like the article? Spread the word