位置: 编程技术 - 正文

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

  • 税款滞纳金和利息
  • 子公司向母公司借款利息税务处理
  • 研发支出属于什么科目借贷方向
  • 自产产品用于业务招待费
  • 资产负债表是根据什么填的
  • 研发项目增值税税率
  • 咨询费开发票选哪一项
  • 物业公司外包保安死亡
  • 购买电脑的折旧怎么计算
  • 印刷宣传册是违法吗
  • 小规模纳税人每个月需要报什么税
  • 纳税调整税收金额
  • 合同副本和正本区别
  • 农牧业没有发票怎么办
  • 纳税人在同一地级行政范围内跨县经营
  • 预付油卡怎么入账
  • 待转销项税额结转分录
  • 没有经营的空壳公司可以贷款吗
  • 生产企业是否可以兼营外贸业务
  • 去年的税金没有计提
  • 上月开的发票本月作废怎么处理
  • 增值税纳税申报表在哪里查询
  • 法人实名认证后为什么查不到名下公司
  • 租车费增值税专用发票
  • 实际出资和名义出资
  • 怎么扣除税费
  • 企业税收有哪些部分组成
  • phpsutdy
  • 公司员工借款怎么做账
  • php常用设计模式(大总结)
  • 向投资者分配现金股利 为什么会导致所有者权益减少?
  • thinkphp pathinfo
  • linux 高并发网络编程
  • 人工智能复试面试常见问题
  • php中验证码如何实现登录验证
  • 即征即退先征后返属于政府补助吗
  • 用现金报销差旅费及增值税怎么做账
  • python 如何调用c
  • 出口退税过期免税申报流程
  • 微信转账和支付宝转账的区别
  • mysql innode
  • SQL(MSSQLSERVER)服务启动错误代码3414的解决方法
  • 主营业务成本应交税费
  • 领备用金填什么单子
  • 甲供材甲方如何缴纳增值税
  • sqlserver强制转换为字符
  • mysql insert语句操作实例讲解
  • 企业所得税汇算表
  • 增值税及附加税费申报表附列资料一
  • 合同资产和合同履约成本的区别
  • 以土地出资的税费怎么算
  • 留底税额怎么形成的
  • 土地回收补偿费怎么算
  • 代扣职工个人所得税的账务处理
  • 银行承兑汇票进行贴现的会计分录
  • 核定征收需要什么资料
  • 银行对账单怎么打印
  • 开一般户需要什么理由
  • windows锁定用户
  • win 10怎么更换系统
  • macbook怎么关闭设置上的1
  • mac怎么卸载第三方软件
  • blg是什么文件
  • linux文本文件格式
  • windows媒体中心关不掉
  • linux yw命令
  • css清除浮动方法有哪几种
  • jquery左右移动动画效果
  • vue3.0diff
  • numpy基础知识
  • javascript 基础篇1 什么是js 建立第一个js程序
  • jquery属性选择器的基本
  • 安卓瀑布流
  • unity类库
  • 土地交易的印花税
  • 陕西国家税务
  • 国家税务总局内蒙古分局
  • 公司外购设备对外投资账务处理
  • 网上订机票怎么取票
  • 会计建账时一般需要哪几本账
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设