Skip to main content

Runs a SQL script against a PostgreSQL, MS-Access, SQLite, MS-SQL-Server, MySQL, MariaDB, or Firebird database, or an ODBC DSN. Provides metacommands to import and export data, copy data between databases, conditionally execute SQL and metacommands, and dynamically alter SQL and metacommands with substitution variables. Data can be exported in 13 different formats, including CSV, TSV, ODS, HTML, JSON, LaTeX, and Markdown tables, and using custom templates.

Project description is a Python program that runs a SQL script stored in a text file against a PostgreSQL, MS-Access, SQLite, MS-SQL-Server, MySQL, MariaDB, or Firebird database, or to an ODBC DSN. also supports a set of special commands (metacommands) that can import and export data, copy data between databases, and conditionally execute SQL statements and metacommands. These metacommands make up a control language that works the same across all supported DBMSs. The metacommands are embedded in SQL comments, so they will be ignored by other script processors (e.g., psql for Postgres and sqlcmd for SQL Server). The metacommands make up a toolbox that can be used to create both automated and interactive data processing applications.

The program’s features and requirements are summarized below. Complete documentation is available at


You can use the execsql program to:

  • Import data from text files or OpenDocument spreadsheets into a database.

  • Copy data between different databases, even databases using different types of DBMSs.

  • Export tables and views as formatted text, comma-separated values (CSV), tab-separated values (TSV), OpenDocument spreadsheets, HTML tables, JSON, LaTeX tables, or unformatted (e.g., binary) data.

  • Export data to non-tabular formats using several different types of template processors.

  • Display tables and views on the console or in a GUI dialog window.

  • Conditionally execute different SQL commands and metacommands based on the DBMS in use, the database in use, data values, user input, and other conditions. Conditional execution can be used with the INCLUDE and SCRIPT metacommands to implement loops.

  • Use simple dynamically-created data entry forms to get user input.

  • Write messages to the console or to a file during the processing of a SQL script, using metacommands embedded in SQL comments. These messages can be used to display the progress of the script or create a custom log of the operations that have been carried out or results obtained. Status messages and data exported in text format can be combined in a single text file. Data tables can be exported in a text format that is compatible with Markdown pipe tables, so that script output can be converted into a variety of document formats.

  • Write more modular and maintainable SQL code by factoring repeated code out into separate scripts, parameterizing the code using substitution variables, and using the INCLUDE or SCRIPT metacommands to merge the modules into a single stream of commands.

  • Standardize the SQL scripting language used for different types of database management systems.

  • Merge multiple elements of a workflow–e.g., data loading, summarization, and reporting–into a single script for better coupling of related steps and more secure maintenance.

Standard SQL provides no features for interacting with external files or with the user, or for controlling the flow of actions to be carried out based either on data or on user input. execsql provides these features in a way that operates identically across all supported DBMSs on both Linux and Windows.

execsql is inherently a command-line program that can operate in a completely non-interactive mode (except for password prompts). Therefore, it is suitable for incorporation into a toolchain controlled by a shell script (on Linux), batch file (on Windows), or other system-level scripting application. When used in this mode, the only interactive elements will be password prompts. However, several metacommands can be used to generate interactive prompts and data displays, so execsql scripts can be written to provide some user interactivity.

In addition, execsql automatically maintains a log that documents key information about each run of the program, including the databases that are used, the scripts that are run, and the user’s choices in response to interactive prompts. Together, the script and the log provide documentation of all actions carried out that may have altered data.

The documentation includes more than 20 examples showing the use of execsql’s metacommands, in both simple and complex scripts.


The execsql program uses third-party Python libraries to communicate with different database and spreadsheet software. These libraries must be installed to use those programs with execsql. Only those libraries that are needed, based on the command line arguments and metacommands, must be installed. The libraries required for each database or spreadsheet application are:

  • PosgreSQL: psycopg2.

  • SQL Server: pydobc.

  • MS-Access: pydobc and pywin32.

  • MySQL or MariaDB: pymysql.

  • Firebird: fdb.

  • DSN connections: pyodbc.

  • OpenDocument spreadsheets: odfpy.

  • Excel spreadsheets (read only): xlrd.

Connections to SQLite databases are made using Python’s standard library, so no additional software is needed.

Recent Changes





Added the ON ERROR_HALT WRITE metacommand.


Added the SUB_APPEND and WRITE SCRIPT metacommands.


Added the PG_VACUUM metacommand.


Modified error message content and format.


Added the “error_response” setting for encoding mismatches.


Modified to handle trailing comments on SQL script lines.


Added a PASSWORD option to the CONNECT metacommand for MySQL/MariaDB.


Modified to allow import of CSV files with more columns than the target table. Added DEBUG metacommands.


Passed headers to template processors as a separate object.


Added the EMAIL, SUB_ENCRYPT, and SUB_DECRYPT metacommands, and configuration proerties to support emailing. Added the METACOMMAND_ERROR_HALT metacommand, the $METACOMMAND_ERROR_HALT_STATE system variable, and the METACOMMAND_ERROR() conditional. Extended the EXPORT metacommand to allow use of different template processors.


Improved speed of IMPORT metacommand for CSV files imported to Postgres and MySQL/MariaDB. Modified the EXPORT…APPEND…AS HTML metacommand to append tables inside the (first) </body> tag.


Modified the specifications for the PROMPT ENTRY_FORM to allow checkboxes to be used.

Project details

Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

execsql- (225.5 kB view hashes)

Uploaded Source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page