mirror of https://github.com/aldy505/sql-dsl.git
Reinaldy Rafli 3478cfb0d8 | ||
---|---|---|
.github/workflows | ||
examples | ||
src | ||
test | ||
.eslintrc.cjs | ||
.gitignore | ||
LICENSE | ||
README.md | ||
package-lock.json | ||
package.json | ||
rollup.config.ts | ||
tsconfig.json |
README.md
SQL DSL for your Node App
Based on an idea from @ronnygunawan. This was supposed to be a challenge for someone else, but I thought, why not? Lol.
As always:
- Supports CJS and ESM
- Built-in typings
- No external dependencies
npm install sql-dsl
What this does?
This outputs simple SQL query & argument object from your template literal string.
import { sql } from 'sql-dsl'
const query = sql`INSERT INTO users (name, email, age) VALUES (${`Thomas Worgdjik`}, ${`thom@thunder.zn`}, ${30})`
// {
// sql: 'INSERT INTO users (name, email, age) VALUES ($1, $2, $3)',
// values: ['Thomas Worgdjik', 'thom@thunder.zn', 30]
// }
// Oh, you work with MySQL instead of Postgres? Sure!
const postgres = query.formatQuestion()
// {
// sql: 'INSERT INTO users (name, email, age) VALUES (?, ?, ?)',
// values: ['Thomas Worgdjik', 'thom@thunder.zn', 30]
// }
// More elegant way to do that is this:
const query = sql`INSERT INTO users (name, email, age) VALUES (${`Thomas Worgdjik`}, ${`thom@thunder.zn`}, ${30})`.formatQuestion()
// Your database work with colon notation? Something like :1 :2 etc? No problem.
const colon = query.formatColon()
// {
// sql: 'INSERT INTO users (name, email, age) VALUES (:1, :2, :3)',
// values: ['Thomas Worgdjik', 'thom@thunder.zn', 30]
// }
// Your database work with @p notation? Yeah, we can do that.
const atp = query.formatAtP()
// {
// sql: 'INSERT INTO users (name, email, age) VALUES (@p1, @p2, @p3)',
// values: ['Thomas Worgdjik', 'thom@thunder.zn', 30]
// }
See more examples with the database drivers on examples.
Hey, I want a feature!
Want more features? Open something up on issues. To be honest, I don't know what else to add.