-
-
Notifications
You must be signed in to change notification settings - Fork 100
/
Copy pathknex.ts
70 lines (52 loc) · 1.73 KB
/
knex.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
import { describe, it, beforeEach, expect } from 'bun:test';
import { newDb } from '../../src/db';
import type { Knex } from "knex";
export async function knexSample() {
// ========= CONNECT ==========
// Create a new DB instance
const mem = newDb();
// create a Knex instance bound to this db
// => This replaces require('knex')({ ... })
const knex = mem.adapters.createKnex() as Knex;
// ========= USE AS USUAL ==========
// Create a table
await knex.schema
.createTable('users', table => {
table.increments('id');
table.string('user_name');
})
// ...and another
.createTable('accounts', table => {
table.increments('id');
table.string('account_name');
table
.integer('user_id')
.unsigned()
.references('users.id');
})
// Then query user table...
await knex('users').insert({ user_name: 'Tim' });
// ... and check
expect(mem.public.many('select * from users'))
.toEqual([{
id: 1,
user_name: 'Tim',
}]);
// Then insert into account table...
await knex('accounts').insert({ account_name: 'knex', user_id: 1 })
// ... and check
expect(mem.public.many('select * from accounts'))
.toEqual([{
id: 1,
account_name: 'knex',
user_id: 1,
}]);
// Try to run a join
const selectedRows = await knex('users')
.join('accounts', 'users.id', 'accounts.user_id')
.select('users.user_name as user', 'accounts.account_name as account')
expect(selectedRows)
.toEqual([
{ user: 'Tim', account: 'knex' },
])
}