LoopBack数据模型定义语言(LDL)完全指南
2025-06-04 02:29:49作者:劳婵绚Shirley
前言
LoopBack数据源Juggler中的模型定义语言(LDL)是定义数据模型的核心工具。本文将全面解析LDL的语法特性、使用场景和最佳实践,帮助开发者高效构建LoopBack应用的数据模型层。
什么是LDL
LDL(LoopBack Definition Language)是一种简洁的领域特定语言,用于在JavaScript或JSON中定义数据模型。它提供了:
- 类型系统:支持基本数据类型和复杂类型
- 模型继承:支持模型间的继承关系
- 关系定义:支持多种模型关联方式
- 数据约束:支持字段级验证规则
- 数据映射:支持与底层数据源的映射配置
基础模型定义
简单JSON定义
{
"id": "number",
"firstName": "string",
"lastName": "string"
}
这个模型定义了三个属性:
id: 数字类型firstName: 字符串类型lastName: 字符串类型
JavaScript定义
var UserDefinition = {
id: Number,
firstName: String,
lastName: String
}
JavaScript版本更为简洁,直接使用类型构造函数。
支持的基本类型
LDL支持以下基本类型:
- String/Text
- Number
- Boolean
- Array
- Object
- Date
- Buffer/Binary
- GeoPoint
类型名称不区分大小写,"Number"和"number"等效。
模型构造器创建
使用ModelBuilder将定义转换为可用的模型构造器:
var ModelBuilder = require('loopback-datasource-juggler').ModelBuilder;
var modelBuilder = new ModelBuilder();
var User = modelBuilder.define('User', {
id: Number,
firstName: String,
lastName: String
});
var user = new User({id: 1, firstName: 'John', lastName: 'Smith'});
模型行为扩展
数据源注入方法
var DataSource = require('loopback-datasource-juggler').DataSource;
var ds = new DataSource('memory');
var User = ds.define('User', UserDefinition);
User.create({id: 1, firstName: 'John', lastName: 'Smith'}, function(err, user) {
// CRUD操作
});
手动添加方法
// 静态方法
User.findByLastName = function(lastName, cb) {
User.find({where: {lastName: lastName}}, cb);
};
// 实例方法
User.prototype.getFullName = function() {
return this.firstName + ' ' + this.lastName;
};
高级模型配置
模型级选项
{
"name": "User",
"options": {
"strict": true, // 是否严格模式
"idInjection": false, // 是否自动注入id
"plural": "users" // 复数形式
},
"properties": {...}
}
属性定义进阶
{
"id": {
"type": "number",
"id": true,
"doc": "用户ID"
},
"firstName": {
"type": "string",
"required": true,
"oracle": {
"column": "FIRST_NAME",
"type": "VARCHAR(32)"
}
}
}
复合ID
var InventoryDefinition = {
productId: {type: String, id: 1},
locationId: {type: String, id: 2},
qty: Number
}
模型关系
一对一关系 (belongsTo)
Order.belongsTo(Customer);
// 使用方式
order.customer(callback);
一对多关系 (hasMany)
Customer.hasMany(Order, {as: 'orders', foreignKey: 'customerId'});
// 使用方式
customer.orders(filter, callback);
多对多关系 (hasAndBelongsToMany)
User.hasAndBelongsToMany('groups', {model: Group, foreignKey: 'groupId'});
// 使用方式
user.groups(callback);
通过中间表的多对多 (hasMany through)
Physician.hasMany(Patient, {through: Appointment});
Patient.hasMany(Physician, {through: Appointment});
模型继承与混入
继承
var Customer = User.extend('customer', {
accountId: String,
vip: Boolean
});
混入
var TimeStamp = modelBuilder.define('TimeStamp', {
created: Date,
modified: Date
});
User.mixin(TimeStamp);
最佳实践
- 命名规范:模型名使用单数形式,属性名使用小驼峰
- 严格模式:生产环境建议启用严格模式
- 文档注释:为重要属性添加doc描述
- 关系设计:根据业务需求选择合适的关系类型
- 类型选择:精确选择数据类型,如Date而非字符串存储时间
总结
LoopBack的模型定义语言提供了强大而灵活的方式来定义数据模型。通过本文的介绍,开发者可以掌握从基础模型定义到复杂关系配置的全套技能,为构建健壮的LoopBack应用打下坚实基础。
登录后查看全文
热门项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0152- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112
项目优选
收起
暂无描述
Dockerfile
733
4.75 K
Ascend Extension for PyTorch
Python
617
795
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.01 K
1.01 K
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
433
395
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
145
237
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
1.18 K
152
暂无简介
Dart
983
252
Oohos_react_native
React Native鸿蒙化仓库
C++
348
403
昇腾LLM分布式训练框架
Python
166
198
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.68 K
989