位置: 编程技术 - 正文

关于在mongoose中填充外键的方法详解(mongoose操作)

编辑:rootadmin

推荐整理分享关于在mongoose中填充外键的方法详解(mongoose操作),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mongoose objectid,mongoose语法,mongoose objectid,mongoose操作,mongoose where,mongoose objectid,mongoose where,mongoose语法,内容如对您有帮助,希望把文章链接给更多的朋友!

本文主要给大家介绍的是关于mongoose中填充外键的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍:

MongoDB

MongoDB是典型的NoSQL数据库,因此不提供JOIN操作。 但有时我们仍然希望引用其他集合中的文档。此时便需要外键填充(population)。 mongoose是极具JavaScript特点的程序库,提供了极其简单和强大的填充功能。 mongoose不仅支持填充单个文档,也支持多文档,甚至直接填充某个对象。

本文中部分代码来自mongoose文档。

外键引用

在Schema字段的定义中,可以添加ref属性来指向另一个Schema。 该ref属性在此后被填充(populate)时将被mongoose读取。 下面是存在互相引用的Person与Story的Schema定义。

外键的类型可以是ObjectId, Number, String, Buffer中任何一种,在赋值与填充时保持一致即可(见下文)。

保存与填充

Story中保存Person对象的_id,此后在Query上调用.populate()即可用Person的文档来替换掉原来的字段。

填充指定的字段

有时我们只想要很少的几个字段,这可以用字段名语法来指定它们。

填充多个属性

有时我们需要填充多个字段,这时可以多次调用.populate() , 也可以在一次调用中指定多个字段:

关于在mongoose中填充外键的方法详解(mongoose操作)

填充引用数组与填充单个引用的语法没有区别,mongoose会识别字段类型的不同。

填充选项

在.populate()的同时,还可以指定过滤器以及限制大小。 将.populate()的参数换为一个对象即可。

上述查询只会选择年龄大于的fans,只返回其name字段,且最多返回5个。

完整的选项请访问: 比如填充用户的朋友的朋友(两级):

注意:多级填充和嵌套属性填充的区别。如果是填充属性的属性(都在当前模型中保存) 则只需要用.分隔,比如: .populate('relations.mother') 。

动态引用

上文中调用.populate()之前有一个条件:被填充的字段已被设置过ref选项。 mongoose会去ref指定的集合中去查找对应ID。 如果是动态字段怎么办?可以在填充的同时指定其ref:

任意对象填充

mongoose不仅可以填充Query中的对象,还可以填充任何对象。 当然这时就需要指定用哪个模型来填充,有两种方式来指定填充模型。

设置populate的model参数

与动态填充类似,填充时可以直接设置model参数。 这时用任意一个Schema都可以操作,比如User:

直接使用对应Schema

直接使用Weapon来填充该类型的属性,则不需要设置model字段:

mongoose会默认使用当前Schema对应的MongoDB的集合。

总结

标签: mongoose操作

本文链接地址:https://www.jiuchutong.com/biancheng/380931.html 转载请保留说明!

上一篇:nodejs动态创建二维码的方法(nodejs创建项目)

下一篇:Mongoose实现虚拟字段查询的方法详解(mongoose模块有什么用途)

  • 小规模30万免增值税1点怎么申报税款
  • 进项税额转出借方科目
  • 水利建设专项资金收入优惠政策
  • 农产品收购发票使用范围
  • 2021年餐饮业的税率是多少?
  • 甲企业持有乙企业的非上市股票2000股
  • 税控盘如何统计开票金额
  • 销售收入做账属于什么凭证
  • 收到投资款需要交税吗?
  • 外账成本倒推表格
  • 购进蔬菜的进项税额
  • 3项经费计提比例2015
  • 税收完税证明分为几种
  • 发票没认证可以作废吗?
  • 老板买增票财务怎么做账
  • 增值税月报时间
  • 销售货物的运输费用计入成本吗知乎
  • 筹建期装修费用计入什么科目
  • 不小心开了发票
  • 物业公司一般纳税人怎么抵扣
  • 员工把发票丢了怎么处理
  • 企业微信收款的钱怎么提取出来
  • 筹建期间的开办费包括哪些
  • 季度利润
  • 2021年windows最新版本
  • 欧拉操作系统和龙蜥哪个好用
  • win10护眼模式在哪
  • 企业所得税汇算清缴补缴税款分录
  • 玫瑰小镇的玫瑰有什么用
  • 如何突出显示一行中的最小值
  • 费用发票开的是跨年的账务处理
  • 商贸企业销售会计分录
  • win11专业版网卡安不了
  • mrmactl.exe
  • ubuntu设置nginx开机启动
  • PHP:mcrypt_generic_init()的用法_Mcrypt函数
  • 固定资产生产经营期间正常报废产生的净收益
  • php遍历结果集
  • java如何实现异步处理
  • php 面向对象
  • 报废机器设备会计分录
  • php输出空格语句
  • 材料合理损耗会计处理
  • 培训费开票属于哪个征收明目
  • 多付款退回怎样写说明
  • php框架是干什么的
  • 长期股权投资的明细科目有哪些
  • 电汇汇款方式的基本流程
  • linux mysql 安装与操作
  • 当月进项发票忘认证又开了销项税额怎么办
  • 工程进度节点奖励考核
  • 资本公积资本溢价怎么算
  • 快捷酒店财务一般几个人
  • 专项费用会计分录
  • 固定资产的后续计量
  • 公司购轿车会计分录怎么做
  • 装饰公司收到的礼品
  • 在建工程进项税额抵扣规定
  • 总账建账要建全部科目吗
  • xp系统重启后自动还原怎么办
  • 怎么用uefi装win7
  • wrsvn.exe是什么
  • 360安全卫士中心未完全开启
  • win8 开机
  • centos7.4升级7.5
  • 安卓软件集
  • Formatting Long Lines 格式化多行字符的shell脚本
  • http状态码一览表
  • javascript可以写算法吗
  • unity3d动画系统
  • python多线程例子
  • jquery渐变效果
  • 股权转让是实缴资本吗
  • 广东省电子学校
  • 国家税务局大厅上班时间
  • 契税计税依据含装修费吗
  • 供热基础设施配套费
  • 出口退税额与出口退税收入
  • 企业支付的年度报告审计费
  • 资源税的税目共有七个其中包括
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设