Skip to content

TheSuperShell/sql-organizer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

  ____   ___  _        ___                        _              
 / ___| / _ \| |      / _ \ _ __ __ _  __ _ _ __ (_)_______ _ __ 
 \___ \| | | | |     | | | | '__/ _` |/ _` | '_ \| |_  / _ \ '__|
  ___) | |_| | |___  | |_| | | | (_| | (_| | | | | |/ /  __/ |   
 |____/ \__\_\_____|  \___/|_|  \__, |\__,_|_| |_|_/___\___|_|   
                                |___/                            

By: Steven Rudenko (steven.gucum@gmail.com)

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

Installation

  • Windows
pip install sql-organizer

Examples

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

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)

  • Specifying file formats
sql-organizer /folder -e txt -e sql

This will find all the files with .txt and .sql formats in the /folder folder

  • Specifying target path
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:

sql-oragnizer /folder -t /my_target.sql --overwrite
  • Choose sorting strategies
sql-organizer /folder -so 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

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 2

  •  
  •  

Languages