mysql
litdb driver for node-mysql2
Install
npm install @litdb/mysql
Usage
db.ts
import { connect } from "@litdb/mysql"
export const connection = connect({ host, database, user, password })
export const { $, async:db, native } = connection
When needed use native
to access underlying node-mysql2 Pool
app.ts
import { $, db } from "./db"
import { Contact } from "./models"
await db.dropTable(Contact)
await db.createTable(Contact)
await db.insertAll([
new Contact({ name:"John Doe", email:"john@mail.org" }),
new Contact({ name:"Jane Doe", email:"jane@mail.org" }),
])
const janeEmail = 'jane@mail.org'
const jane = await db.one<Contact>($.from(Contact).where(c => $`${c.email}=${janeEmail}`))
const { lastInsertRowid:bobId } = await db.insert(
new Contact({ name:"Bob", email:"bob@mail.org"}))
const { lastInsertRowid } = await db.exec
`INSERT INTO Contact(name,email) VALUES('Jo','jo@doe.org')`
const name = 'Alice', email = 'alice@mail.org'
await db.exec`INSERT INTO Contact(name,email) VALUES (${name}, ${email})`
const hasId = <Table extends { id:number }>(id:number|bigint) =>
(x:Table) => $.sql($`${x.id} = $id`, { id })
const contacts = await db.all($.from(Contact).into(Contact))
const bob = await db.one($.from(Contact).where(hasId(bobId)).into(Contact))
const contactsCount = await db.value($.from(Contact).select`COUNT(*)`)
const emails = await db.column($.from(Contact).select(c => $`${c.email}`))
const contactsArray = await db.arrays($.from(Contact))
const bobArray = await db.array($.from(Contact).where(hasId(bobId)))
jane.email = 'jane@doe.org'
await db.update(jane)
await db.update(jane, { onlyProps:['email'] })
await db.exec($.update(Contact).set({ email:jane.email }).where(hasId(jane.id)))
await db.delete(jane)
await db.exec($.deleteFrom(Contact).where(hasId(jane.id)))
Website: https://litdb.dev