A CFML wrapper for the Vertical Blank sql-formatter java library.
Using CommandBox:
box install sqlFormatter
Basic formatting is done via the format()
method:
var prettySQL = getInstance( "Formatter@sqlformatter" )
.format( "SELECT COUNT(*) FROM users" );
For database-specific syntax, you can choose a dialect using .of()
:
var prettySQL = getInstance( "Formatter@sqlformatter" )
.of( "postgres" )
.format( "SELECT COUNT(*) FROM users" );
You can also specify advanced configuration options via the ConfgBuilder
:
var formatConfig = getInstance( "ConfigBuilder@sqlformatter" )
.setIndent(" ") // Defaults to two spaces
.setUppercase(true) // Defaults to false (not safe to use when SQL dialect has case-sensitive identifiers)
.setLinesBetweenQueries(2) // Defaults to 1
.setMaxColumnLength(80) // Defaults to 50
.build();
You can then pass the FormatConfig
object as the second parameter in the Formatter.format()
method call:
var prettySQL = getInstance( "Formatter@sqlformatter" )
.format( "SELECT * FROM pages ORDER BY 'name'", formatConfig );
SQLFormatter supports parameter replacement using either an array of parameters or a struct of key/value params passed to the .withParams()
method.
For positional parameters, pass an array:
var prettySQL = getInstance( "Formatter@sqlformatter" )
.of( "mysql" )
.withParams( [ "a", "b", "c" ] )
.format( "SELECT * FROM pages WHERE slug IN [?, ?, ?]" );
or for named parameters, use a key/value struct:
var prettySQL = getInstance( "Formatter@sqlformatter" )
.of( "postgres" )
.withParams( { "name" : "Michael", "age" : "18" } )
.format( "SELECT * FROM user WHERE name= :michael and age= :age" );
Warning: Only certain dialects support parameters, and each dialect uses different syntax. Use the
postgresql
dialect for the:name
syntax, ortsql
for@foo
syntax.
Warning: There is an issue in the underlying library with named placeholders. See issue #57 on the SQLFormatter repository for more details.
sql
- Standard SQLmariadb
- MariaDBmysql
- MySQLpostgresql
- PostgreSQLdb2
- IBM DB2plsql
- Oracle PL/SQLn1ql
- Couchbase N1QLredshift
- Amazon Redshiftspark
- Sparktsql
- SQL Server Transact-SQL
Special thanks to the SQLFormatter library. I could'na dunnit without ya. 😉
All contributions welcome! Fixing typos or adding tests are especially easy ways to help out.
To get started hacking on SQLFormatter:
- Clone the module -
git clone git@github.com:michaelborn/sqlFormatter.git
- Install dependencies -
box install
- Start up a Lucee server -
box server start serverConfigFile=server-lucee@5.json
- Write code
- Run tests -
box testbox run
- Push up a pull request
To bump the embedded SQLFormatter library, run the following from the module directory root - making sure to replace 2.0.3
with the latest version number:
rm lib/sql-formatter-*.jar && cd lib && curl -LO https://search.maven.org/remotecontent?filepath=com/github/vertical-blank/sql-formatter/2.0.3/sql-formatter-2.0.3.jar
This should place a sql-formatter-<VERSION>.jar
jar file in the lib/
directory. All that's needed after that is a git add lib && git commit && git push
to update the repo.
Copyright Since 2005 ColdBox Framework by Luis Majano and Ortus Solutions, Corp www.coldbox.org | www.luismajano.com | www.ortussolutions.com
Because of His grace, this project exists. If you don't like this, then don't read it, its not for you.
"Therefore being justified by faith, we have peace with God through our Lord Jesus Christ: By whom also we have access by faith into this grace wherein we stand, and rejoice in hope of the glory of God. And not only so, but we glory in tribulations also: knowing that tribulation worketh patience; And patience, experience; and experience, hope: And hope maketh not ashamed; because the love of God is shed abroad in our hearts by the Holy Ghost which is given unto us. ." Romans 5:5
"I am the way, and the truth, and the life; no one comes to the Father, but by me (JESUS)" Jn 14:1-12