| Crates.io | rust-sql-organizer |
| lib.rs | rust-sql-organizer |
| version | 1.0.0 |
| created_at | 2025-07-30 16:03:09.527526+00 |
| updated_at | 2025-07-30 16:03:09.527526+00 |
| description | This is a simple rust CLI tool to organize .sql files. This is a useful tool for my work, but I decided to share it as a project example |
| homepage | https://github.com/TheSuperShell/rust-sql-organizer |
| repository | https://github.com/TheSuperShell/rust-sql-organizer |
| max_upload_size | |
| id | 1773704 |
| size | 41,090 |
____ ___ _ ___ _
/ ___| / _ \| | / _ \ _ __ __ _ __ _ _ __ (_)_______ _ __
\___ \| | | | | | | | | '__/ _` |/ _` | '_ \| |_ / _ \ '__|
___) | |_| | |___ | |_| | | | (_| | (_| | | | | |/ / __/ |
|____/ \__\_\_____| \___/|_| \__, |\__,_|_| |_|_/___\___|_|
|___/
By: Steven Rudenko (steven.gucum@gmail.com)
This is a rust port of this project: https://github.com/TheSuperShell/sql-organizer
This project is inspired by a problem I had at work where I would get billion seperate .sql files to execute one by one and had to manually copy them into a one worksheet. This CLI tool automates this process. It also sorts the files based on chosen strategies (I will introduce more in the future). Ofcourse this tool can be used with any file format, but since this is manly used for my SQL problem - I named it SQL Organizer :D
Let's say you have a folder /folder with a bunch of .sql files (the current directory will be used by default). If you run the following command
rust-sql-organizer /folder
the tool will generate a target.sql file with the combined text from all the .sql files in the /folder (the search is recursive)
rust-sql-organizer /folder -e txt -e sql
This will find all the files with .txt and .sql formats in the /folder folder
rust-sql-organizer /folder -t /my_target.sql
this will put the result into the my_target.sql file. The command will error if the file already exists by default, if you want to overwrite it put --overwrite parameter:
rust-sql-organizer /folder -t /my_target.sql --overwrite
rust-sql-organizer /folder -s last_number
You can also chain the startegies, the priority is determined by the position, higher to lower priority Here are all the available strategies for now
| Stategy | Descrition |
|---|---|
| first_number | The ordering is based on the fist number found in the file name. 0 will be used if no number is found Example: 100_SCRIPT_2.sql -> 100 will be used for sorting |
| last_number | The ordering is based on the last number found in the file name. 0 will be used if no number is found Example: 100_SCRIPT_2.sql -> 2 will be used for sorting |
| folder | The name of the last folder will be used for soring. Sorting is done in an alphabetical order Example: my/folder/100_SCRIPT.sql -> folder will be used for soring |
Use parameter --out with the file path to write the utput into the file
rust-sql-organizer /folder --out output.log