Vercel Postgres, no transactions?
I had problems using Kysely on Vercel Postgres, with the @vercel/postgres
and @vercel/postgres-kysely
adapters.
Basically, transactions are not supported.
I had some code like this:
const data = await db.transaction().execute(async (trx) => {
const somedata = await trx
.selectFrom('table1')
.selectAll()
.where('id', '=', token)
.executeTakeFirst()
if (!somedata) throw new Error('Invalid data')
await trx
.deleteFrom('table2')
.where('id', '=', token)
.executeTakeFirst()
return somedata
})
console.log(data)
and I had to remove the transaction, I just used the queries without the transaction:
const data = await db.selectFrom('table1')
.selectAll()
.where('id', '=', token)
.executeTakeFirst()
if (!data) throw new Error('Invalid data')
await db.deleteFrom('table2')
.where('id', '=', token)
.executeTakeFirst()
console.log(data)
Hopefully transactions will be implemented.
If you absolutely need them you can still use a direct connection to the database using pg
I wrote 21 books to help you become a better developer:
- HTML Handbook
- Next.js Pages Router Handbook
- Alpine.js Handbook
- HTMX Handbook
- TypeScript Handbook
- React Handbook
- SQL Handbook
- Git Cheat Sheet
- Laravel Handbook
- Express Handbook
- Swift Handbook
- Go Handbook
- PHP Handbook
- Python Handbook
- Linux Commands Handbook
- C Handbook
- JavaScript Handbook
- Svelte Handbook
- CSS Handbook
- Node.js Handbook
- Vue Handbook