Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kysely-org/kysely-knex
A toolkit (dialect, type translators, custom migration source, etc.) that allows using your existing Knex setup with Kysely.
https://github.com/kysely-org/kysely-knex
Last synced: 3 months ago
JSON representation
A toolkit (dialect, type translators, custom migration source, etc.) that allows using your existing Knex setup with Kysely.
- Host: GitHub
- URL: https://github.com/kysely-org/kysely-knex
- Owner: kysely-org
- License: mit
- Created: 2024-01-01T23:17:22.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-05-28T18:33:08.000Z (7 months ago)
- Last Synced: 2024-05-29T15:30:37.264Z (7 months ago)
- Language: TypeScript
- Homepage:
- Size: 200 KB
- Stars: 12
- Watchers: 2
- Forks: 1
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-kysely - link - knex?style=flat-square) <br/>![GitHub stars](https://img.shields.io/github/stars/kysely-org/kysely-knex?style=flat-square) <br/>![NPM](https://img.shields.io/npm/l/kysely-knex?style=flat-square) | (Adapters)
- awesome-opensource-israel - kysely-knex - A toolkit (dialect, type translators, custom migration source, etc.) that allows using your existing Knex setup with Kysely. ![GitHub last commit](https://img.shields.io/github/last-commit/kysely-org/kysely-knex?style=flat-square "GitHub last commit") ![GitHub top language](https://img.shields.io/github/languages/top/kysely-org/kysely-knex?style=flat-square "GitHub top language") ![GitHub stars](https://img.shields.io/github/stars/kysely-org/kysely-knex?style=flat-square) (Projects by main language / typescript)
README
# kysely-knex
Knex.js (pronounced /kəˈnɛks/) is a "batteries included" SQL query builder for PostgreSQL, CockroachDB, MSSQL, MySQL, MariaDB, SQLite3, Better-SQLite3, Oracle, and Amazon Redshift designed to be flexible, portable, and fun to use. It features both traditional node style callbacks as well as a promise interface for cleaner async flow control, a stream interface, full-featured query and schema builders, transaction support (with savepoints), connection pooling and standardized responses between different query clients and dialects.
As of Mar 29, 2024, Knex has 1,625,784 weekly downloads on npm (3rd most popular SQL library). It is a very popular query builder for Node.js and TypeScript.
Knex IS legendary, but since it was created before TypeScript blew up, it's type capabilities are nothing to write home about. This why Kysely was created.
Kysely (pronounced “Key-Seh-Lee”) is a type-safe and autocompletion-friendly TypeScript SQL query builder. Inspired by Knex. Mainly developed for Node.js but also runs on Deno and in the browser.
kysely-knex is a toolkit (dialect, type translators, custom migration source, etc.) that allows using your existing Knex setup with Kysely. This'll allow you to gradually migrate your codebase from Knex to Kysely.
## Installation
Main dependencies:
```sh
npm install kysely kysely-knex knex
```PostgreSQL:
```sh
npm install pg pg-query-stream # pg-query-stream is optional, used in .stream() method
```MySQL:
```sh
npm install mysql2 # or mysql
```MS SQL Server (MSSQL):
```sh
npm install tedious
```SQLite:
```sh
npm install better-sqlite3 # or sqlite3
```## Usage
### Types
If you have already defined your Knex `Tables` interface, you can convert it using
the `KyselifyTables` type:`src/types/database.ts`:
```ts
import type {Tables} from 'knex/types/tables'
import type {KyselifyTables} from 'kysely-knex'export type Database = KyselifyTables
```Otherwise, refer to the [Kysely documentation](https://kysely.dev/docs/getting-started#types) for more information.
### Kysley instance
Create a Kysely instance. Pass it your existing Knex instance:
`src/kysely.ts`:
```ts
import {Kysely} from 'kysely'
import {KyselyKnexDialect, PGColdDialect} from 'kysely-knex'
import {knex} from './knex'
import type {Database} from './types/database'export const kysely = new Kysely({
dialect: new KyselyKnexDialect({
knex,
kyselySubDialect: new PGColdDialect(),
}),
})
```For other dialects, simply swap `PGColdDialect` with `MySQLColdDialect`, `MySQL2ColdDialect`, `MSSQLColdDialect`, `SQLite3ColdDialect` or `BetterSQLite3ColdDialect`.
### Migrations
There are a few ways to tackle migrations given you have an existing Knex migration setup:
1. Delete all existing migrations and start fresh with Kysely migrations.
2. Use our [custom migration source](https://knexjs.org/guide/migrations.html#custom-migration-sources) `KyselyFsMigrationSource` to provide a Kysely instance to your Knex-managed migrations:`migrations/20240101000000_add_email_column.ts`:
```ts
import type {Knex} from 'knex'
import type {Kysely} from 'kysely'export async function up(_: Knex, kysely: Kysely): Promise {
await kysely.schema
.alterTable('dog_walker')
.addColumn('email', 'varchar', (cb) => cb.unique())
.execute()
}export async function down(_: Knex, kysely: Kysely): Promise {
await kysely.schema.alterTable('dog_walker').dropColumn('email').execute()
}
```Pass the migration source to all migrate commands as follows:
`scripts/migrate-to-latest.ts`:
```ts
import {join} from 'node:path'
import {KyselyFsMigrationSource, PGColdDialect} from 'kysely-knex'
import {knex} from '../src/knex'
import {kysely} from '../src/kysely'export const migrationSource = new KyselyFsMigrationSource({
kyselySubDialect: new PGColdDialect(),
migrationDirectories: join(__dirname, '../migrations'),
})await knex.migrate.latest({migrationSource})
```or pass it to Knex CLI globally:
`knexfile.ts`:
```ts
const {KyselyFsMigrationSource, PGColdDialect} = require('kysely-knex')module.exports = {
// ...
migrations: {
// ...
migrationSource: new KyselyFsMigrationSource({
kyselySubDialect: new PGColdDialect(),
migrationDirectories: 'migrations',
}),
// ...
},
// ...
}
```This'll allow you to seamlessly transition to only use Kysely from a certain point in time. Then, you could gradually convert existing Knex migration files to use Kysely instead of Knex, as all migrations now receive a Kysely instance.
More ways to tackle this topic might be provided in the future. Stay tuned!