Skip to main content

No project description provided

Project description

SQLecto

SQLecto is a command-line tool for converting SQL queries across different SQL dialects, providing flexibility for users working with SQL transformations. This tool leverages the powerful SQLGlot library for parsing and transpiling SQL queries.

Features

  • Dialect Conversion: Transpile SQL queries from one SQL dialect to another (e.g., Spark to Snowflake)
  • File Support: Process individual SQL/Python files or entire directories containing SQL code
  • Configurable Mappings: Define custom table mappings and configurations via JSON or YAML files

Requirements

  • Python 3.8+

Quck Start

Installation

You can install SQLecto via pipx (recommended) or pip.

Using pipx

pipx install sqlecto

Using pip

pip install sqlecto

Basic Usage

Convert a single SQL file:

sqlecto --source-dialect spark --target-dialect snowflake --source-files ./my_query.sql

Convert all SQL files in a directory

sqlecto --source-dialect spark --target-dialect snowflake --source-dir ./sql_scripts

Command Options

Option Required Description Default
--source-files No SQL/Python files to process None
--source-dir No Directory containing SQL/Python files Current directory
--source-dialect Yes Source SQL dialect None
--target-dialect Yes Target SQL dialect None
--table-mappings No Table name mappings None
--table-mappings-file No File containing table mappings None
--config-file No Configuration file path None
--output-dir No Output directory for converted files ./transpiled_queries

Example Command

sqlecto --source-dialect spark --target-dialect snowflake \
    --source-dir ./sql_scripts --output-dir ./transpiled_queries

Configuration

Configuration File Example

Configuration can be managed via JSON or YAML files, allowing reusable settings:

{
  "source_files": ["./path/to/file.sql", "./path/to/file2.py"],
  "source_dialect": "spark",
  "target_dialect": "snowflake",
  "output_dir": "./transpiled_queries",
  "table_mappings": [{ "src_table": "old_table", "dst_table": "new_table" }]
}

Table Mappings

To replace table names within SQL queries, use --table-mappings or specify mappings in a configuration file. Mappings follow the format:

--table-mappings source_table:target_table

Or in JSON/YAML:

"table_mappings": [
    {"src_table": "old_table", "dst_table": "new_table"}
]
# mappings.yaml
table_mappings:
  - src_table: old_table1
    dst_table: new_table1
  - src_table: old_table2
    dst_table: new_table2

Examples

Basic Conversion

sqlecto --source-dialect spark --target-dialect snowflake \
    --source-files ./query.sql --output-dir ./converted

Directory Processing with Table Mappings

sqlecto --source-dialect spark --target-dialect snowflake \
    --source-dir ./sql_scripts \
    --table-mappings old_db.table1:new_db.table1 \
    --output-dir ./converted

Using Configuration File

sqlecto --config-file ./config.yaml

Credits

This tool heavily relies on the SQLGlot package by Toby Mao, providing robust and reliable SQL dialect transformations.

Contributing

Contributions are welcome! Please fork the repository and create a pull request for any improvements.

License

MIT License

Project details


Download files

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

Source Distribution

sqlecto-0.0.1.tar.gz (6.7 kB view details)

Uploaded Source

Built Distribution

sqlecto-0.0.1-py3-none-any.whl (7.8 kB view details)

Uploaded Python 3

File details

Details for the file sqlecto-0.0.1.tar.gz.

File metadata

  • Download URL: sqlecto-0.0.1.tar.gz
  • Upload date:
  • Size: 6.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for sqlecto-0.0.1.tar.gz
Algorithm Hash digest
SHA256 0e74af60d48297e082966b65e1f8e4986b9e2c8e16d1d1f1e0900f784f530d15
MD5 88fdfd2c2ce5df8564f51432b074a7d9
BLAKE2b-256 ac84cb4aa685b29093fb26efc8a665f44af95745c72b96267eee538e87510221

See more details on using hashes here.

Provenance

The following attestation bundles were made for sqlecto-0.0.1.tar.gz:

Publisher: release.yaml on valdAsync/sqlecto

Attestations:

File details

Details for the file sqlecto-0.0.1-py3-none-any.whl.

File metadata

  • Download URL: sqlecto-0.0.1-py3-none-any.whl
  • Upload date:
  • Size: 7.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for sqlecto-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 73b65a62a34ab00efb969966d2206bc78c8c9a92a0ef08671278dc36917aa655
MD5 2879c3928b69c9fe951d54695d62a786
BLAKE2b-256 f403b487cecf81afec0eeee213b265ad1cece6727378f571e58a31051a8cf793

See more details on using hashes here.

Provenance

The following attestation bundles were made for sqlecto-0.0.1-py3-none-any.whl:

Publisher: release.yaml on valdAsync/sqlecto

Attestations:

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