Mongoose中lean()与非lean()查询的类型差异处理
2025-05-06 11:12:17作者:秋泉律Samson
在使用Mongoose操作MongoDB时,开发者经常会遇到需要处理Decimal128类型数据的情况。本文将深入探讨如何在使用lean()和非lean()查询时正确处理类型差异,特别是针对Decimal128类型的转换问题。
问题背景
Mongoose提供了两种查询文档的方式:
- 标准查询:返回完整的Mongoose文档实例
- lean查询:返回普通的JavaScript对象
当我们需要处理Decimal128类型字段时,这两种方式会带来类型差异。标准查询会应用schema中定义的getter转换,而lean查询则直接返回原始数据。
解决方案一:单独定义lean类型
最直接的解决方案是为lean查询单独定义一个类型:
interface IOrder {
total: Decimal
}
type IOrderLean = { total?: mongoose.Types.Decimal128 };
const Order = mongoose.model<IOrder>('Order', orderSchema)
// 使用示例
const orderTotal: Decimal = (await Order.findOne().orFail()).total;
const leanOrderTotal = await Order.findOne().orFail().lean<IOrderLean>();
这种方法简单直接,但需要维护两个类型定义。
解决方案二:使用HydratedDocument类型
更符合Mongoose设计理念的做法是:
interface IOrder {
total?: mongoose.Types.Decimal128
}
type OrderHydratedDocument = mongoose.HydratedDocument<
IOrder,
{ total?: Decimal }
>;
const Order = mongoose.model<IOrder, OrderModelType>('Order', orderSchema)
// 使用示例
const orderTotal: Decimal | undefined = (await Order.findOne().orFail()).total;
const leanOrderTotal = await Order.findOne().orFail().lean();
这种方案中:
- 基础接口IOrder表示MongoDB中存储的原始类型
- HydratedDocument类型表示经过Mongoose处理后的文档类型
- 通过泛型参数确保类型安全
最佳实践建议
- 对于简单项目,方案一更易于理解和实现
- 对于大型项目或需要严格类型安全的场景,推荐使用方案二
- 无论哪种方案,都应该在schema中明确定义getter函数,确保类型转换的一致性
总结
Mongoose的lean查询和非lean查询在类型处理上存在差异,特别是在使用自定义getter时。通过合理使用TypeScript的泛型和Mongoose提供的HydratedDocument类型,我们可以构建类型安全的应用程序,同时享受lean查询带来的性能优势。开发者应根据项目规模和复杂度选择适合的方案。
登录后查看全文
热门项目推荐
相关项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5-w4a8GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术,结合vLLM推理优化,高效平衡性能与精度,助力智能应用开发Jinja00
jiuwenclawJiuwenClaw 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。Python0193- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
AtomGit城市坐标计划AtomGit 城市坐标计划开启!让开源有坐标,让城市有星火。致力于与城市合伙人共同构建并长期运营一个健康、活跃的本地开发者生态。01
awesome-zig一个关于 Zig 优秀库及资源的协作列表。Makefile00
热门内容推荐
项目优选
收起
deepin linux kernel
C
27
12
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
601
4.04 K
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
Ascend Extension for PyTorch
Python
441
531
AscendNPU-IR是基于MLIR(Multi-Level Intermediate Representation)构建的,面向昇腾亲和算子编译时使用的中间表示,提供昇腾完备表达能力,通过编译优化提升昇腾AI处理器计算效率,支持通过生态框架使能昇腾AI处理器与深度调优
C++
112
170
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.46 K
824
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
922
770
暂无简介
Dart
846
204
React Native鸿蒙化仓库
JavaScript
321
375
openGauss kernel ~ openGauss is an open source relational database management system
C++
174
249