Package Exports
- sql-formatter-plus-jinja
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (sql-formatter-plus-jinja) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
SQL Formatter Plus Jinja
A fork of SQL Formatter with support for Jinja SQL.
SQL Formatter is a JavaScript library for pretty-printing SQL queries. It started as a port of a PHP Library, but has since considerably diverged. It supports Standard SQL, Couchbase N1QL, IBM DB2 and Oracle PL/SQL dialects.
Install
Get the latest version from NPM:
npm install sql-formatter-plus-jinja
Usage
import sqlFormatter from 'sql-formatter-plus-jinja';
console.log(sqlFormatter.format('SELECT * FROM table1'));
This will output:
SELECT
*
FROM
table1
You can also pass in configuration options:
sqlFormatter.format('SELECT *', {
language: 'n1ql', // Defaults to "jinja"
indent: ' ', // Defaults to two spaces,
uppercase: true, // Defaults to false
linesBetweenQueries: 2 // Defaults to 1
});
Currently just four SQL dialects are supported:
- sql - Standard SQL
- n1ql - Couchbase N1QL
- db2 - IBM DB2
- pl/sql - Oracle PL/SQL
Placeholders replacement
// Named placeholders
sqlFormatter.format("SELECT * FROM tbl WHERE foo = @foo", {
params: {foo: "'bar'"}
}));
// Indexed placeholders
sqlFormatter.format("SELECT * FROM tbl WHERE foo = ?", {
params: ["'bar'"]
}));
Both result in:
SELECT
*
FROM
tbl
WHERE
foo = 'bar'
Usage without NPM
If you don't use a module bundler, clone the repository, run npm install
and grab a file from /dist
directory to use inside a <script>
tag.
This makes SQL Formatter available as a global variable window.sqlFormatter
.
Contributing
# run linter and tests
npm run check
...and you're ready to poke us with a pull request.