位置: 编程技术 - 正文

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

  • 城建税和教育费附加
  • 月收入10万以下免税哪些企业适用
  • 企业增值税必须退税吗?
  • 民办非企业业务主管单位职责
  • 去年的费用票会计分录
  • 自然人独资企业是什么意思
  • 公司之间房产过户免税条件
  • 委托加工物资增值税怎么算
  • 月初结存材料成本差异
  • 金融企业税务稽查案例分析
  • 小规模纳税人汇算清缴要填什么表
  • 租赁房屋房产税
  • 未分配利润转增股本要交税吗
  • 一次性付清的优缺点
  • 一般纳税人企业所得税政策最新2023税率
  • 股东转账实收资本怎么填
  • 分支机构多预缴应该怎么退税呢?
  • 小微企业分公司 企业所得税优惠
  • 查账征收企业所得税年度申报
  • 营改增土地增值税的计算
  • 已开专票在哪里查询
  • 海关年检需要什么资料
  • 商业承兑汇票风险
  • 公司账户有钱怎么取出来
  • 城镇土地使用税优惠政策
  • thinkphp6调用模型的方法
  • 商业承兑汇票提示承兑期限
  • 多付货款退回的法律依据
  • linux 分享文件
  • 报销差旅费怎么算
  • linux内核与文件系统
  • 最早的拍照手机是哪一年
  • php如何防止xss攻击
  • 用应付票据付应付账款
  • Salzburg with Salzach river, Austria (© MacEaton/Alamy)
  • 图像质量评价指标及方法 图像工程
  • PostMan接口测试(很全面的接口测试教程)
  • 企业季度所得税怎么算
  • 股东分红税率是20%还是25%
  • gawk命令 模式扫描与处理语言
  • 小企业发票打印流程
  • 境外企业在境内提供服务 企业所得税
  • 培训费用是什么成本
  • 域名费用怎么交
  • 红冲后的发票税怎么办
  • 织梦面包屑导航最后的分隔符大于号去掉方法
  • 坏账准备计入科目
  • 股东滥用股东权利
  • 建筑劳务公司何去何从
  • 小规模纳税人有哪些
  • 实收资本期末需要结转吗
  • 利息收入如何入会计科目
  • 制造费用期末有余额在借方
  • 为什么要进行结账和对账
  • 物业所在地是指物业住所地吗
  • 以货物抵应收账款的分录
  • 付给农民的土地使用费
  • 固定资产处置如何申报企业所得税
  • 公司缴纳社保如何转为个人缴纳
  • 票据利率定价调整方案
  • 苗木种植发票免税怎么开
  • 其他应收款明细表怎么填
  • 会计凭证审核标准有哪些
  • 原始凭证的主要内容包括
  • 原始凭证的会计分录
  • sql server?
  • microsoft window vista
  • 电脑开机时出现红色三角形
  • win7 windows安全
  • windows8语言栏不见了
  • 电脑因故障出现问题而启动
  • linux怎么使用ssh命令
  • linux find命令的使用
  • bat 参数个数
  • python%怎么用
  • js中的三种弹出消息提醒的命令
  • jquery兼容ie
  • android StrictMode使用
  • 商铺土地增值税预缴税率是多少
  • 机动车检测属于哪个税收
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设