位置: 编程技术 - 正文

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

发布时间:2024-02-27

推荐整理分享关于在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模块有什么用途)

  • 应纳附加税是什么
  • 补发上年度奖金如何计税
  • 应收应付账务处理工作具体做哪些
  • 工程项目罚款收入账务处理
  • 发票预付款充值卡是否报销
  • 小企业会计准则和一般企业会计准则的区别
  • 单位交的社保明年能退吗
  • 累计纳税工资是什么意思
  • 收到境外汇款怎么处理
  • 国资委无偿划拨资产不上税吗
  • 哪些属于不动产权
  • 期间费用的控制方法主要有
  • 外汇税收怎么缴纳增值税
  • 没收履约保证金交增值税吗
  • 收到违约金需要缴纳所得税吗
  • 交际应酬费用
  • 预缴税多交了,税务局退吗
  • 2016年营改增后购买氧气乙炔税率是多少
  • 公司购买新办公楼装修计入什么科目
  • 小微企业季度所得税怎么计算
  • 住宿专票怎么入账
  • 存货占比小有什么影响
  • 资产负债表里应交税费里都包含什么
  • 免抵税额增值税主表体现到哪里的
  • 在会计上其他业务是什么
  • 受伤员工补贴
  • 法院执行款可以开发票吗
  • 企业研发过程中特殊收入的会计处理
  • 联营 保底
  • 支付水电费如何记账
  • 关于暂时性差异的所得税会计处理,正确的是
  • 分公司吸收新股怎么办
  • phpif判断语句
  • 销项负数发票应该给谁
  • 完工产品成本怎么算
  • PHP:pg_field_table()的用法_PostgreSQL函数
  • vue3项目打包
  • php traits
  • 怎么启用framework3.5
  • 预付装修费的会计处理分录
  • php中的表达式简写是什么
  • 公司客户招待费用标准
  • 制造业企业资金如何循环周转
  • 发票的普票和专票什么区别
  • 公司名下商品房过户给公司需要交过户费
  • 域名费用怎么交
  • 发票纳税识别号和名称打印出来不齐怎么回事
  • 会计实操和实际工作一样吗
  • 公司人员工资计算方法
  • 享受专项附加扣除要什么时候申报
  • 小规模购进原材料可以抵扣税金吗
  • 外购产品用于职工福利企业所得税视作销售吗
  • 上市公司回购股票多久可出售
  • 其他业务收入怎么申报增值税
  • 增值税进项税额抵扣期限最新
  • 工程收据怎么开表格
  • 进项税转出补缴增值税 城建税及两费
  • 工资的税额
  • 企业投资所得如何征税
  • 速动比率特别高的原因
  • sqlserver数据库备份
  • 微软发布linux
  • fedora32
  • wincomm.exe - wincomm是什么进程
  • 如何隐藏文件夹并显示隐藏的文件夹
  • win8怎么玩帝国时代2
  • XP系统升级WIN7系统
  • webgl基础教程
  • shell脚本符号
  • javascript的判断语句
  • linux中awk用法详解
  • unity3d模型怎么制作
  • python相关图片
  • android 图片裁剪 任意形状
  • 公司的完税证明必须打印吗
  • 党建阵地作用发挥不好
  • 苏州社保代缴机构查询
  • 单位纪检员和纪检委员区别
  • 专票一个单位一张可以吗
  • 为什么10月份社保交不了
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号