Skip to content

Exports SQL Tables and Views to CSV files and then also optionally uploads them to an FTP site for integrations with cloud systems and provide an easier solution compared with SSIS which will often not work well with large text fields

License

Notifications You must be signed in to change notification settings

robinwilson16/CSVSQLExporter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CSV SQL Exporter

This tool exports SQL Tables and Views to CSV files and then also optionally uploads them to an FTP site for integrations with cloud systems and provide an easier solution compared with SSIS which will often not work well with large text fields

If you are looking for a tool that works the other way around exporting from CSV into SQL then please see the other project instead:

https://github.com/robinwilson16/CSVSQLImporter

Excel Tools

I have also produced Excel tools for importing and exporting which work in the same way as the CSV tools and are available here:

https://github.com/robinwilson16/ExcelSQLImporter

https://github.com/robinwilson16/ExcelSQLExporter

Purpose

The tool was created as a replacement for Microsoft SQL Integration Services (SSIS) which can work well with smaller files but these days has a lot of limitations which this tool overcomes:

  • CSV columns that contain a large number of characters can be exported without any errors or changes being made to settings
  • All rows are evaluated when setting column sizes to avoid errors you get with SSIS when the first rows contain less data than subsequent rows and the column size is set to the maximum size needed (for the importer)
  • Data types are detected automatically so will export correctly without code page errors, truncated values, missing values where a column mixes text and numbers
  • The tool is simpler to use as just requires .NET 9 runtime to be installed and does not require any other data access components or any other special settings

Prereqisites

You will need to install the Microsoft .NET Runtime 9.0 available from: https://dotnet.microsoft.com/en-us/download/dotnet/9.0 Nothing else needs to be installed as this software can just be unzipped and run.

Setting Up

Download the latest release from: https://github.com/robinwilson16/CSVSQLExporter/releases/latest

If you have an Intel/AMD machine (most likely) then pick the amd64 version but if you have a an ARM Snapdragon device then pick the arm64 version.

Download and extract the zip file to a folder of your choice.

Now edit the appsettings.json to fill in details for:

Item Purpose
Database Connection Connection to the database to read data
Database Table Where you are getting the data from which should be a table or view
CSV File Where you are saving the data to which should be a file ending in .csv and whether to include column headings on the first line
FTP Connection (Optional) Where you are then uploading the saved CSV file to

Once all settings are entered then just click on CSVSQLExporter.exe to run the program. If you notice any errors appearing in the window then review these, change the settings file and try again.

Exporting Multiple Files

By default configuration values are picked up from appsettings.json but in case you want to use the tool to export multiple Database Tables or Views then when running from the commandline specify the name of the config file after the .exe so to pick up settings from a config file called FinanceExport.json execute:

CSVSQLExporter.exe FinanceExport.json

Setting Up a Schedule

You can just click on may wish to set up a schedule to export one or more CSV files each night and the best way to do this in Windows is to use Task Scheduler which is available in all supported versions of Windows.

Create a new task and name it based on the Excel file it will export so for example:

CSVSQLExporter - Finance Data

Pick a user account to run the task against. If you used Windows Authentication in your settings file then you will need to pick a user account with sufficient permissions to read the database table or view you are exporting as well as save the CSV file if it is on a network drive.

On the Triggers tab select a schedule such as each day at 18:00.

On the Actions tab specify the location of the CSV SQL Export tool under Program/script (you can use browse to pick it). It should show as something similar to:

D:\CSVSQLExporter\CSVSQLExporter.exe

Optionally if you are exporting more than one file then enter the name of this into the arguments box for each task you set up - e.g.:

UsersTable.json

About

Exports SQL Tables and Views to CSV files and then also optionally uploads them to an FTP site for integrations with cloud systems and provide an easier solution compared with SSIS which will often not work well with large text fields

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages