位置: 编程技术 - 正文

关于在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模块有什么用途)

  • 计提并结转所得税费用的会计分录
  • 计提税金账务处理
  • 企业一般纳税人是什么意思
  • 其他货币资金的科目编码
  • 增值税发票的抵扣联丢了怎么办
  • 计提缴纳印花税怎么做账
  • 个体工商户注销后的责任承担问题
  • 关联企业往来业务包括
  • 生产企业有哪些费用
  • 税控机减免税额怎么算
  • 不征税收入税收政策
  • 设备维保费税率怎么算
  • 出口企业增值税优惠政策
  • 电话费补贴属于免税收入吗
  • 红字发票不小心点了暂存怎么办
  • 应收账款融资的会计如何核算
  • 进项税和销项税借贷方向
  • 员工工资漏申报怎么办
  • 收到预付款是否确认收入
  • 代账会计的职责
  • 上月有留底税额,这个月有销销没有进项怎么做账
  • 跟踪路由如何实现
  • 网页视频播放不流畅原因
  • 其他业务收入跨年调账
  • 招待费如何列支
  • 事业单位财产清查怎么进行
  • php实战
  • 单位购买降暑用品
  • zendstudio写好程序怎样运行
  • 前后端分离与不分离
  • php年月日时间代码
  • 最多显示2行文字怎么弄
  • axios请求数据的数据类型
  • 消费税增值税和个人所得税是什么意思
  • 应收票据到期后账务处理
  • 小规模附加税减免政策2023
  • 委托代销商品支付的手续费计入什么科目
  • 财务负责人需要承担什么风险
  • 对方企业倒闭了是否能函证
  • 印花税如何计算缴纳
  • 可抵扣进项税额的六种类型
  • 进项税额大于销项税额期末留抵
  • 实收资本(或股本)是什么意思
  • 营改增后建筑业开票规定
  • 资本公积的相关资料
  • 购买税控盘用银行抵扣吗
  • 增值税纳税申报表在哪里打印
  • 其他应收款怎么冲平
  • 设置ubuntu
  • windows XP+Fedora 8+solaris 11三系统安装攻略
  • 电脑百度搜索
  • MAC百度网盘下载的压缩包怎么导出
  • macbookair网页全屏
  • win7开机连不上网
  • XP下HTTP的403.9错误-禁止访问:连接的用户过多 重启iis可以解决
  • hdaudpropshortcut.exe是什么进程 作用是什么 hdaudpropshortcut进程查询
  • windows7脚本编程和命令行指南
  • win7如何设置屏幕不黑屏
  • win7累计更新补丁包
  • cocos creator性能
  • js操作list
  • 正则表达\d
  • 常用的批处理命令
  • shell脚本进程号
  • android broadcast
  • node.js express koa
  • 键盘搜索的快捷键
  • android software
  • 图片旋转鼠标键盘怎么弄
  • 莱鸟人集团
  • android如何导入v4包
  • Android调用系统截屏方法
  • 公共基础设施项目目录
  • 换电脑了税控盘怎么办
  • 12366人工服务时间节假日上班吗
  • 注册会计师和注册建造师哪个难考
  • 国家税务总局商洛市税务局
  • 地税注销流程
  • 紧缩性财政政策有哪些
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设