2 releases
0.1.1 |
|
---|---|
0.1.0 |
|
0.1.0-alpha.11 | Apr 9, 2023 |
0.1.0-alpha.6 | Jun 11, 2022 |
#2315 in Command line utilities
24 downloads per month
340KB
2.5K
SLoC
SQLx-ts
SQLx-ts is a CLI application featuring compile-time checked queries without a DSL and prevents broken SQL queries being run during runtime.
- Compile time checked queries - never ship a broken SQL query to production
- TypeScript type generations - generates type definitions based on the raw SQLs and you can use them with any MySQL or PostgreSQL driver
- Database Agnostic - support for PostgreSQL and MySQL
- TypeScript and JavaScript - supports for both TypeScript and JavaScript
Installation
Install sqlx-ts npm module
If you are using npm
$ npm install sqlx-ts
If you are using yarn
$ yarn add sqlx-ts
And to use sqlx-ts in your code
In TypeScript based projects:
import { sql } from 'sqlx-ts'
// ...
const query = sql`SELECT * FROM some_table;`
// ...
In Babel based projects:
import { sql } from 'sqlx-ts'
const query = sql`SELECT * FROM some_table;`
// ... or
const { sql } = require('sqlx-ts')
const query = sql`SELECT * FROM some_table;`
Installing binary
Using cargo
To install sqlx-ts using cargo
$ cargo install sqlx-ts
Using install.sh
The binary name for sqlx-ts is sqlx-ts
.
Archives of precompiled binaries of sqlx-ts are available for Windows, macOS and Linux. Linux and Windows binaries are static executables. Users of platforms not explicitly mentioned below are advised to download one of these archives.
If you're a macOS user, then you can install sqlx-ts from via install.sh:
$ curl -LSfs https://jasonshin.github.io/sqlx-ts/install.sh | \
sh -s -- --os macos
If you're a Windows user, then you can install sqlx-ts from via install.sh:
$ curl -LSfs https://jasonshin.github.io/sqlx-ts/install.sh | \
sh -s -- --os win32
If you're a Linux user, then you can install sqlx-ts from via install.sh:
$ curl -LSfs https://jasonshin.github.io/sqlx-ts/install.sh | \
sh -s -- --os linux
To install a specific artifact, go to the release page to find the exact name of the artifact
$ curl -LSfs https://jasonshin.github.io/sqlx-ts/install.sh | \
sh -s -- --artifact sqlx_ts_v0.1.0_x86_64-apple-darwin.tar.gz
Upgrading to a new version can be done by grabbing the next version of the sqlx-ts artifact and use --force
command from install.sh
$ curl -LSfs https://jasonshin.github.io/sqlx-ts/install.sh | \
sh -s -- --artifact sqlx_ts_v0.2.0_x86_64-apple-darwin.tar.gz --force
For more advanced usage, please check --help
command of install.sh
$ curl -LSfs https://jasonshin.github.io/sqlx-ts/install.sh | \
sh -s -- --help
Motivation
Rust's philosophy of guaranteed compile-time safety of your code has always inspired me. Rust is still new and many seasoned developers would view Rust's increased benefit/cost ratio claims are as yet unproven. However, there are lessons from these new technologies that we can bring back to our everyday languages such as JavaScript and TypeScript. SQLx is a great example of this, although the idea isn't directly co-related to Rust, but its philosophy well-aligns with Rust's overall ecosystem.
Dependencies
~26–42MB
~713K SLoC