尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

在Vona ORM中实现多数据库/多数据源

在Vona ORM中实现多数据库/多数据源
📅 发布时间:2026/6/19 17:32:55
在Vona ORM中实现多数据库/多数据源在Vona ORM中实现多数据库/多数据源非常直观、简便。下面以 Model User/Order 为例,通过查询用户的订单列表,来演示多数据库/多数据源的使用方法

在Vona ORM中实现多数据库/多数据源非常直观、简便。下面以 Model User/Order 为例,通过查询用户的订单列表,来演示多数据库/多数据源的使用方法

准备Models

先准备两个 Models:User/Order

  1. Model Order
@Model({entity: EntityOrder,
})
class ModelOrder{}
  • 需要指定ModelOrder关联的Entity,限于篇幅,EntityOrder代码从略
  1. Model User
@Model({entity: EntityUser,relations: {orders: $relation.hasMany(() => ModelOrder, 'userId'),},
})
class ModelUser {}
  • 在ModelUser中定义1:n关系: orders

查询数据

然后查询用户的订单列表

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

到目前为止,使用系统默认数据源查询到了userId=1的用户信息,和该用户的所有订单列表

创建多数据源

接下来,创建两个数据源:user-pg和order-mysql

1. 添加数据源的类型定义

  • 在 VSCode 中,通过右键菜单Vona Init/Types在模块中创建类型文件

  • 然后在类型文件中添加类型定义

{module path}/src/types/index.ts

declare module 'vona-module-a-orm' {export interface IDatabaseClientRecord {'user-pg': never;'order-mysql': never;}
}
  • IDatabaseClientRecord是模块vona-module-a-orm提供的接口类型。在这里通过接口合并的机制来添加新的数据源类型

2. 数据源配置

在项目的App config文件中定义数据源的配置信息。由于前面已经添加了数据源类型,在App config文件中就可以享受完整的类型提示

src/backend/config/config/config.ts

// database
config.database = {clients: {'user-pg': {client: 'pg',connection: {host: '127.0.0.1',port: 5432,user: 'postgres',password: '',database: 'user-xxx',},},'order-mysql': {client: 'mysql2',connection: {host: '127.0.0.1',port: 3306,user: 'root',password: '',database: 'order-xxx',},},},
};
  • user-pg: 使用数据库方言:pg
  • order-mysql: 使用数据库方言:mysql2

使用数据源:动态方式

可以在代码中动态使用数据源:

class ServiceOrder {async selectUserOrders() {const userId = 1;
+   const modelUser = this.scope.model.user.newInstance('user-pg');const userAndOrders = await modelUser.get({id: userId,},{include: {orders: true,},},);}
}  
  • newInstance: 传入要使用的数据源,返回新的 Model 实例

到目前为止,使用数据源user-pg查询用户信息,使用系统默认数据源查询订单列表

使用数据源:Relation动态选项

可以在 relation 选项中动态指定数据源:

class ServiceOrder {async selectUserOrders() {const userId = 1;const modelUser = this.scope.model.user.newInstance('user-pg');const userAndOrders = await modelUser.get({id: userId,},{include: {orders: {
+           meta: {
+             client: 'order-mysql',
+           },},},},);}
}  
  • meta.client: 指定 relation orders要使用的数据源

到目前为止,使用数据源user-pg查询用户信息,使用数据源order-mysql查询订单列表

使用数据源:Model配置

也可以直接在 Model 中配置数据源,从而简化查询代码

  1. Model Order
@Model({entity: EntityOrder,
+ client: 'order-mysql',
})
class ModelOrder{}
  • 在VonaJS框架中,可以非常方便的为@Model装饰器指定参数
  1. Model User
@Model({entity: EntityUser,
+ client: 'user-pg',relations: {orders: $relation.hasMany(() => ModelOrder, 'userId'),},
})
class ModelUser {}
  1. 查询数据

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

class ServiceOrder {async selectUserOrders() {const userId = 1;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:user': {client: 'user-pg',},'test-vona:order': {client: 'order-mysql',},},
};
  • 在VonaJS框架中,可以在App Config文件中提供配置,用于覆盖对应Model的options配置

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

使用数据源:Relation静态选项

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

@Model({entity: EntityUser,client: 'user-pg',relations: {orders: $relation.hasMany(() => ModelOrder, 'userId', {
+     meta: {
+       client: 'order-mysql',
+     },}),},
})
class ModelUser {}

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

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

相关新闻

  • sql over()函数使用
  • 小柏实战学习Liunx(图文教程三十二)
  • VPX处理板设计原理图:9-基于DSP TMS320C6678+FPGA XC7V690T的6U VPX信号处理卡 C6678板卡, XC7VX690T板卡, VPX处理板

最新新闻

  • 3分钟掌握Web Audio API声音变换:Voice Change-O-Matic终极指南
  • 深入解析MC9S08QG8内部时钟源(ICS)模块:FLL原理、七种工作模式与实战配置
  • 如何永久保存微信聊天记录:3步完成数据备份的完整指南
  • 第36章:PagedAttention Kernel 与 KV Cache 内存布局
  • React Native Map Link测试策略:单元测试与集成测试最佳实践
  • (2026新)烟台正规防水补漏公司口碑榜TOP5权威推荐!卫生间/厨房/阳台/屋顶/天花板/地下室渗漏水检测维修攻略-靠谱漏水检测维修师傅推荐 - 安佳防水

日新闻

  • 信任的进化:技术实现详解——如何用JavaScript构建博弈论模拟器
  • Terrakube自定义工作流:如何集成OPA、Infracost等工具扩展IaC能力
  • grunt-concurrent快速入门:5分钟学会并行运行Grunt任务

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号