位置: 编程技术 - 正文

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

  • 一般纳税人内账税金的处理
  • 怎么做税种
  • 什么是税收制度构成要素的中心环节
  • 税金及附加怎么登账
  • 工程项目的存货含哪些科目
  • 财产损失税务备案
  • 商场返现活动怎么入账
  • 差额事业单位发放科研奖励记账
  • 进项转出后是否要交税
  • 自然人独资属于个体工商户吗?
  • 税收和征税
  • 个税税务稽查
  • 挂靠费如何纳税?
  • 个体纳税申报核定销售额填不填
  • 外籍人士劳务费怎么交税
  • 成本费用跨年度怎么计算
  • 现金存入对公账户用途写什么
  • 存货跌价准备如何结转
  • 增值税价外费用开票内容
  • 应收账款结转下年要画红线吗
  • 即征即退收入是否计入三免三减半所得
  • 企业增速怎么算
  • 进项是普票销项是专票,怎么交税
  • win7系统如何设置热点
  • 报销冲借款是什么意思
  • 如何在excel中计算两列数值的差
  • 安卓手机数据迁移到红米手机
  • 未计发放待遇
  • 计提折旧和计提减值
  • 进出口公司出口退税额
  • 生产员工福利计什么科目
  • 哪些发票不能进账
  • uniapp打开系统设置
  • 生产性生物资产折旧计入什么科目
  • nginx配置伪静态规则
  • 超级鸽卫星
  • 旅游景点html代码
  • 有形动产的租赁增值税税率是多少
  • ulimit设置不生效
  • sudo权限是什么意思
  • 对方代垫保险费算不算入账价值
  • php面试知识点
  • 建筑公司预收账款财税怎么处理
  • 手机话费怎么打发票
  • 零申报季报怎么报税的具体流程
  • 增值税抵扣进项税额什么意思
  • c++ abort函数
  • 小型公司怎么做账
  • SQL Server 2008+ Reporting Services (SSRS)使用USER登录问题
  • 施工企业期间费用 企业管理费会计分录
  • 固定资产清理损益表怎么填
  • 往酒吧送酒怎么样
  • 商业企业库存商品成本核算
  • 挂靠工程如何交纳税金帐务处理?
  • 公司对员工的罚款有什么标准
  • 销项税票怎么开
  • 国际航班怎么报销
  • 如果以前做了错事怎么办
  • 发票商品编码表
  • 会计记账基础有哪两种
  • win7怎么设置麦克风权限
  • win8关机后自动重启怎么办
  • win10右键菜单不显示
  • linux中ftp命令的用法
  • cocos2djs
  • cocos2dx官方教程
  • 服务器防arp欺骗怎么解决
  • shell脚本-lt
  • Linux Shell中判断进程是否存在的方法
  • sdk官方网站
  • 脚本 python
  • python优先级顺序
  • js分享软件集合
  • 税务局三级主办是副科吗
  • 商铺 评估价
  • 纳税人识别号不能含有IOZSV
  • 进项税额的抵扣凭证
  • 网上申报增值税纳税申报表怎么填写
  • 重庆税务总局发票查询
  • 辽宁国税征期日历
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设