Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/blakeembrey/sql-template-tag
ES2015 tagged template string for preparing SQL statements, works with `pg`, `mysql`, `sqlite` and `oracledb`
https://github.com/blakeembrey/sql-template-tag
mysql oracle-db pg postgresql sql sql-query sql-query-builder sqlite template-tags
Last synced: 4 days ago
JSON representation
ES2015 tagged template string for preparing SQL statements, works with `pg`, `mysql`, `sqlite` and `oracledb`
- Host: GitHub
- URL: https://github.com/blakeembrey/sql-template-tag
- Owner: blakeembrey
- License: mit
- Created: 2018-05-06T12:21:16.000Z (over 6 years ago)
- Default Branch: main
- Last Pushed: 2024-04-21T00:21:20.000Z (9 months ago)
- Last Synced: 2025-01-12T05:05:21.764Z (11 days ago)
- Topics: mysql, oracle-db, pg, postgresql, sql, sql-query, sql-query-builder, sqlite, template-tags
- Language: TypeScript
- Homepage:
- Size: 1.13 MB
- Stars: 361
- Watchers: 4
- Forks: 19
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
README
# SQL Template Tag
[![NPM version][npm-image]][npm-url]
[![NPM downloads][downloads-image]][downloads-url]
[![Build status][build-image]][build-url]
[![Build coverage][coverage-image]][coverage-url]> ES2015 tagged template string for preparing SQL statements.
## Installation
```
npm install sql-template-tag --save
```## Usage
```js
import sql, { empty, join, raw } from "sql-template-tag";const query = sql`SELECT * FROM books WHERE id = ${id}`;
query.sql; //=> "SELECT * FROM books WHERE id = ?"
query.text; //=> "SELECT * FROM books WHERE id = $1"
query.statement; //=> "SELECT * FROM books WHERE id = :1"
query.values; //=> [id]pg.query(query); // Uses `text` and `values`.
mysql.query(query); // Uses `sql` and `values`.
oracledb.execute(query); // Uses `statement` and `values`.// Embed SQL instances inside SQL instances.
const nested = sql`SELECT id FROM authors WHERE name = ${"Blake"}`;
const query = sql`SELECT * FROM books WHERE author_id IN (${nested})`;// Join and "empty" helpers (useful for nested queries).
sql`SELECT * FROM books ${hasIds ? sql`WHERE ids IN (${join(ids)})` : empty}`;
```### Join
Accepts an array of values or SQL, and returns SQL with the values joined together using the separator.
```js
const query = join([1, 2, 3]);query.sql; //=> "?,?,?"
query.values; //=> [1, 2, 3]
```**Tip:** You can set the second argument to change the join separator, for example:
```js
join(
[sql`first_name LIKE ${firstName}`, sql`last_name LIKE ${lastName}`],
" AND ",
); // => "first_name LIKE ? AND last_name LIKE ?"
```### Raw
Accepts a string and returns a SQL instance, useful if you want some part of the SQL to be dynamic.
```js
raw("SELECT"); // == sql`SELECT`
```**Do not** accept user input to `raw`, this will create a SQL injection vulnerability.
### Empty
Simple placeholder value for an empty SQL string. Equivalent to `raw("")`.
### Bulk
Accepts an array of arrays, and returns the SQL with the values joined together in a format useful for bulk inserts.
```js
const query = sql`INSERT INTO users (name) VALUES ${bulk([
["Blake"],
["Bob"],
["Joe"],
])}`;query.sql; //=> "INSERT INTO users (name) VALUES (?),(?),(?)"
query.values; //=> ["Blake", "Bob", "Joe"]
```## Recipes
This package "just works" with [`pg`](https://www.npmjs.com/package/pg), [`mysql`](https://www.npmjs.com/package/mysql), [`sqlite`](https://www.npmjs.com/package/sqlite) and [`oracledb`](https://www.npmjs.com/package/node-oracledb).
### [MSSQL](https://www.npmjs.com/package/mssql)
```js
mssql.query(query.strings, ...query.values);
```### Stricter TypeScript
The default value is `unknown` to support [every possible input](https://github.com/blakeembrey/sql-template-tag/pull/26). If you want stricter TypeScript values you can create a new `sql` template tag function.
```ts
import { Sql } from "sql-template-tag";type SupportedValue =
| string
| number
| SupportedValue[]
| { [key: string]: SupportedValue };function sql(
strings: ReadonlyArray,
...values: Array
) {
return new Sql(strings, values);
}
```## Related
Some other modules exist that do something similar:
- [`sql-template-strings`](https://github.com/felixfbecker/node-sql-template-strings): promotes mutation via chained methods and lacks nesting SQL statements. The idea to support `sql` and `text` properties for dual `mysql` and `pg` compatibility came from here.
- [`pg-template-tag`](https://github.com/XeCycle/pg-template-tag): missing TypeScript and MySQL support. This is the API I envisioned before writing this library, and by supporting `pg` only it has the ability to [dedupe `values`](https://github.com/XeCycle/pg-template-tag/issues/5#issuecomment-386875336).## License
MIT
[npm-image]: https://img.shields.io/npm/v/sql-template-tag
[npm-url]: https://npmjs.org/package/sql-template-tag
[downloads-image]: https://img.shields.io/npm/dm/sql-template-tag
[downloads-url]: https://npmjs.org/package/sql-template-tag
[build-image]: https://img.shields.io/github/actions/workflow/status/blakeembrey/sql-template-tag/ci.yml?branch=main
[build-url]: https://github.com/blakeembrey/sql-template-tag/actions/workflows/ci.yml?query=branch%3Amain
[coverage-image]: https://img.shields.io/codecov/c/gh/blakeembrey/sql-template-tag
[coverage-url]: https://codecov.io/gh/blakeembrey/sql-template-tag