当前位置: 首页 > news >正文

Vona ORM分表全攻略

分表

针对高并发、数据量大的场景,通常会考虑采用分表机制进行优化。下面以 Model User/Order 为例,通过查询用户的订单列表,来演示分表的使用方法

分表规则

比如需要对订单表进行分表操作。可以根据实际业务需求设计分表规则,在这里,根据用户Id取模动态生成表名。比如,拆分为16张表,用户Id129,对应的表名如下:

const tableName = `Order_${129 % 16}`;  // Order_1

准备Models

先准备两个 Models:User/Order

  1. Model Order
@Model({entity: EntityOrder,
})
class ModelOrder{}
  1. Model User
@Model({entity: EntityUser,relations: {orders: $relation.hasMany(() => ModelOrder, 'userId'),},
})
class ModelUser {}

查询数据

1. 直接查询订单列表

class ServiceOrder {async selectOrdersDirectly() {const userId = 129;const orders = await this.scope.model.order.select({where: {userId,},});}
}  

到目前为止,使用默认表名查询userId=129的订单列表

2. 基于关系查询订单列表

class ServiceOrder {async selectOrdersByRelation() {const userId = 129;const userAndOrders = await this.scope.model.user.get({id: userId,}, {include: {orders: true,},});}
}  

到目前为止,使用默认表名查询userId=129的用户信息,使用默认表名查询该用户的订单列表

使用分表:动态方式

可以在代码中动态使用分表:

class ServiceOrder {async selectOrdersDirectly() {const userId = 129;
+   const tableName = `Order_${userId % 16}`;
+   const modelOrder = this.scope.model.order.newInstance(undefined, tableName as any);const orders = await modelOrder.select({where: {userId,},});}
}  
  • newInstance: 传入要使用的表名,返回新的 Model 实例

到目前为止,使用分表查询userId=129的订单列表

使用分表:Relation动态选项

可以在 relation 选项中动态指定表名:

class ServiceOrder {async selectOrdersByRelation() {const userId = 129;
+   const tableName = `Order_${userId % 16}`;const userAndOrders = await this.scope.model.user.get({id: userId,}, {include: {orders: {
+         meta: {
+           table: tableName as any,
+         },},},});}
}  
  • meta.table: 指定 relation orders要使用的表名

到目前为止,使用默认表名查询userId=129的用户信息,使用分表查询该用户的订单列表

使用分表:Model配置

也可以直接在 Model 中配置分表规则,从而简化查询代码

  1. Model Order
@Model({entity: EntityOrder,
+ table(_ctx: VonaContext, where: EntityOrder | undefined, defaultTable: keyof ITableRecord) {
+   const userId = where?.userId;
+   if (!userId) return defaultTable;
+   return `Order_${Number(userId) % 16}`;
+ },
})
class ModelOrder{}
  • table: 指定函数,实现分表规则
  1. 查询数据

现在,又可以使用常规的方式查询用户的订单列表

class ServiceOrder {async selectOrdersDirectly() {const userId = 129;const orders = await this.scope.model.order.select({where: {userId,},});}
}  
class ServiceOrder {async selectOrdersByRelation() {const userId = 129;const userAndOrders = await this.scope.model.user.get({id: userId,}, {include: {orders: true,},});}
}  

使用分表:App Config配置

也可以在 App config 中配置 Model options:

src/backend/config/config/config.ts

// onions
config.onions = {model: {'test-vona:order': {table(_ctx: VonaContext, where: EntityOrder | undefined, defaultTable: keyof ITableRecord) {const userId = where?.userId;if (!userId) return defaultTable;return `Order_${Number(userId) % 16}`;},},},
};

于是,也可以使用常规的方式查询用户的订单列表

使用分表:Relation静态选项

也可以在定义 Relation 时指定静态选项:

@Model({entity: EntityUser,relations: {orders: $relation.hasMany(() => ModelOrder, 'userId', {
+     meta: {
+       table(_ctx: VonaContext, where: EntityOrder | undefined, defaultTable: keyof ITableRecord) {
+         const userId = where?.userId;
+         if (!userId) return defaultTable;
+         return `Order_${Number(userId) % 16}`;
+       },
+     },}),},
})
class ModelUser {}

同样,也可以使用常规的方式查询用户的订单列表

Vona ORM已开源:github.com/vonajs/vona

http://www.rkmt.cn/news/11609.html

相关文章:

  • 深入解析:设计模式-状态模式详解
  • 如何让百度快速收录网页如何让百度快捷收录网页的方法
  • 061_尚硅谷_算术运算符课堂练习
  • axi 4k边界检测
  • GOSIM 开源出海工作坊:给开源创业者的忠告
  • 一文搞懂Flex弹性布局空间分配规则
  • “小身材的大心脏”——HT-AD3PS-1+ 在成都恒利泰的射频江湖里到底做了什么?
  • AT_agc012_c [AGC012C] Tautonym Puzzle 题目分析
  • 详细介绍:回调函数与错误处理
  • .NET操作Word/WPS打造专业文档 - 页面设置与打印控制完全指南
  • NORDIC蓝牙6.0新品NRF54L15多协议超低功耗高性能BLE芯片 - 动能世纪
  • 快速入门HarmonyOS应用开发(三) - 教程
  • Docker + IDEA 一键部署! - 实践
  • Manim实现涟漪扩散特效
  • Xcode 26.0.1 (17A400) 发布 - Apple 平台 IDE
  • CNN+MNIST - 实践
  • 微算法科技(NASDAQ: MLGO)利用高级 Blowfish 加密标准实现区块链集成信息共享
  • Docker常用命令速查
  • 深入解析:gpt-4o+deepseek+R生成热力图表
  • PostgreSQL 的索引Ooracle、Mysql索引的类型对比和说明
  • Docker打包CMake项目镜像操作步骤
  • 【智慧】 gym104385
  • __repr__魔术方法
  • 合合信息获首批“个人信息保护合规审计自审计能力评价”最高等级认证
  • 微云二手车运营版系统:多端覆盖的二手车平台解决方案
  • Linux常见命令1
  • Unigine整合Myra UI Library全纪录(1)
  • ABAP 调用HTTP上传附件中文乱码
  • PDF入参以及模板对应签章图踩坑点 JAR版本为 iText5
  • 雷达系统杂波设计与仿真