news 2026/1/10 1:41:45

Node生态中最优雅的数据库事务处理机制

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Node生态中最优雅的数据库事务处理机制

使用装饰器启用事务

事务传播机制

事务补偿机制

确保数据库与缓存数据一致性

使用装饰器启用事务

import { Database } from 'vona-module-a-orm';

class ServicePost {

@Database.transaction()

async transaction() {

// insert

const post = await this.scope.model.post.insert({

title: 'Post001',

});

// update

await this.scope.model.post.update({

id: post.id,

title: 'Post001-Update',

});

}

}

手工启用事务

1. 使用当前数据源

class ServicePost {

async transactionManually() {

const db = this.bean.database.current;

await db.transaction.begin(async () => {

await this.scope.model.post.update({ id: 1, title: 'Post001_Update' });

});

}

}

2. 使用指定数据源

class ServicePost {

async transactionManually() {

const db = this.bean.database.getDb({ clientName: 'default' });

await db.transaction.begin(async () => {

const modelPost = this.scope.model.post.newInstance(db);

await modelPost.update({ id: 1, title: 'Post001_Update' });

});

}

}

事务参数

class ServicePost {

@Database.transaction({

+ isolationLevel: 'READ_COMMITTED',

+ propagation: 'REQUIRED'

})

async transaction() {

...

}

}

class ServicePost {

async transactionManually() {

const db = this.bean.database.getDb({ clientName: 'default' });

await db.transaction.begin(

async () => {

...

},

{

+ isolationLevel: 'READ_COMMITTED',

+ propagation: 'REQUIRED',

}

);

}

}

事务参数:isolationLevel

名称 说明

DEFAULT 数据库相关的缺省isolationLevel

READ_UNCOMMITTED

READ_COMMITTED

REPEATABLE_READ

SERIALIZABLE

SNAPSHOT

事务参数:propagation

Vona ORM 支持数据库事务传播机制

名称 说明

REQUIRED 默认的事务传播级别。如果当前存在事务, 则加入该事务。如果当前没有事务, 则创建一个新的事务

SUPPORTS 如果当前存在事务,则加入该事务. 如果当前没有事务, 则以非事务的方式继续运行

MANDATORY 强制性。如果当前存在事务, 则加入该事务。如果当前没有事务,则抛出异常

REQUIRES_NEW 创建一个新的事务。如果当前存在事务, 则把当前事务挂起。也就是说不管外部方法是否开启事务,总是开启新的事务, 且开启的事务相互独立, 互不干扰

NOT_SUPPORTED 以非事务方式运行。如果当前存在事务,则把当前事务挂起(不用)

NEVER 以非事务方式运行。如果当前存在事务,则抛出异常

事务补偿机制

当事务成功或者失败时执行一些逻辑

1. 成功补偿

this.bean.database.current.commit(async () => {

// do something when success

});

2. 失败补偿

this.bean.database.current.compensate(async () => {

// do something when failed

});

事务与Cache数据一致性

许多框架使用最简短的用例来证明是否高性能,而忽略了业务复杂性带来的性能挑战。随着业务的增长和变更,项目性能就会断崖式下降,各种优化补救方案让项目代码繁杂冗长。而 Vona 正视大型业务的复杂性,从框架核心引入缓存策略,并实现了二级缓存、Query缓存和Entity缓存等机制,轻松应对大型业务系统的开发,可以始终保持代码的优雅和直观

Vona 系统对数据库事务与缓存进行了适配,当数据库事务失败时会自动执行缓存的补偿操作,从而让数据库数据与缓存数据始终保持一致

针对这个场景,Vona 提供了内置的解决方案

1. 使用当前数据源

class ServicePost {

@Database.transaction()

async transaction() {

// insert

const post = await this.scope.model.post.insert({

title: 'Post001',

});

// cache

await this.scope.cacheRedis.post.set(post, post.id);

}

}

当新建数据后,将数据放入 redis 缓存中。如果这个事务出现异常,就会进行数据回滚,同时缓存数据也会回滚,从而让数据库数据与缓存数据保持一致

2. 使用指定数据源

class ServicePost {

async transactionManually() {

const db = this.bean.database.getDb({ clientName: 'default' });

await db.transaction.begin(async () => {

const modelPost = this.scope.model.post.newInstance(db);

const post = await modelPost.insert({ title: 'Post001' });

await this.scope.cacheRedis.post.set(post, post.id, { db });

});

}

}

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/5 4:56:52

使用格子玻尔兹曼方法(LBM)模拟热扩散的Matlab代码

使用格子玻尔兹曼方法(LBM)模拟热扩散,Matlab代码格子玻尔兹曼方法(LBM)搞热扩散模拟其实挺有意思的,今天咱们用Matlab整一个简单的二维版本。先上核心思路:把温度场当作被动标量,用…

作者头像 李华
网站建设 2026/1/5 4:57:04

ORACLE学习笔记总结(数据库参数文件)

Oracle数据库参数文件详解与操作指令 一、参数文件类型概述 Oracle数据库使用两种参数文件来存储实例配置&#xff1a; 1. PFILE&#xff08;Parameter File&#xff09; 文件类型&#xff1a;文本文件&#xff0c;可直接编辑 默认名称&#xff1a;init<SID>.ora&…

作者头像 李华
网站建设 2026/1/4 14:58:48

浅谈:算法中的斐波那契数(六)

方法五&#xff1a;矩阵求幂斐波那契数列矩阵方程&#xff1a;算法&#xff1a;若 N 小于等于 1&#xff0c;则返回 N。使用递归函数matrixPower 计算给定矩阵 A 的幂。幂为 N-1&#xff0c;其中 N 是第 N 个 斐波那契数。matrixPower 函数将对 N/2 个斐波那契数进行操作。在 m…

作者头像 李华
网站建设 2026/1/6 16:59:54

BioSIM抗人TGFB1抗体SIM0367:适用广泛,功能多样

在生命科学领域&#xff0c;抗体作为研究和治疗的核心工具&#xff0c;其质量与性能直接影响实验结果的准确性和可靠性。随着生物技术的不断进步&#xff0c;越来越多的高质量生物类似药产品进入市场&#xff0c;为科研工作者提供了更加经济、高效的解决方案。其中&#xff0c;…

作者头像 李华
网站建设 2026/1/5 6:27:46

软件测试环境搭建全流程指南

在软件开发的生命周期中&#xff0c;测试环境是保证产品质量的关键基础设施。一个稳定、可靠的测试环境能够准确模拟生产环境&#xff0c;帮助测试人员及时发现缺陷&#xff0c;降低线上风险。本文将从环境规划、搭建步骤、维护管理三个维度&#xff0c;为测试从业者提供一套完…

作者头像 李华