位置: 编程技术 - 正文

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

  • 开出销项发票和进项票成本有出入怎么办?
  • 出口退税是先交税后退税吗
  • 零申报公司注销麻烦吗
  • 红冲以前年度的费用怎么做账
  • 公司的货款直接到账吗
  • 个人所得税专项扣除子女教育标准
  • 股份支付为什么计入股本溢价
  • 增值税专用发票几个点
  • 小微企业开票多少算小规模纳税人
  • 劳务派遣小规模纳税人税率是多少
  • 外地预交的附加税金在申报的时候怎么填
  • 纳税申报 财务报表利润表
  • 一般纳税人劳务税率是多少2023
  • 实收资本资本公积盈余公积均属于投资者投入企业的资本
  • 员工集体旅游费会计分录
  • 无形资产原值变动账务处理
  • 订金退回怎么做账
  • 自营建造固定资产的账务处理
  • 在PDF里怎么将A4缩小转换为一半打印出来
  • 一般纳税人以清包工方式
  • 企业税前扣除凭证包括以下哪些方面
  • 6%的增值税发票能抵扣13%的吗
  • 追补确认年度是哪一年
  • 研发费用的
  • 税务咨询费用
  • 个人转租房子
  • 鸿蒙系统开发人员选项
  • 高速过路费抵扣进项怎么填报
  • 员工没有工资卡可以转到一个人的账户上发工资不
  • 销售自己使用过的物品的税率
  • 网页读出来
  • 不动产在建工程领用原材料的分录
  • 工业企业成本核算方法
  • react router教程
  • html5开发的app有哪些
  • 自学前端好学吗
  • html代码form
  • ai绘画图片
  • bcdboot命令怎么用
  • 赠送的物品有价值吗
  • 权益法转换为成本法
  • 购入固定资产怎么做账务处理
  • 石油预付款发票怎么开
  • mysql的innodb引擎支持外键
  • sqlserver使用awe分配内存
  • sql聚合语句
  • 工业企业出租设备租金计入什么科目
  • 用商品抵债的分类有哪些
  • 福利企业增值税退税标准
  • 老板买了手机,算入什么费用
  • 药店医保收入如何查询
  • 出口报关金额怎么算
  • 费用报销单填写标准
  • 给股东分利润怎么做账
  • 进项税转出税额
  • 2023最新税收优惠政策有哪些
  • 手写账目表格怎么做
  • 本年利润的会计科目
  • 会计准则应收账款计提坏账
  • mysql数据库内存缓存设置
  • windows自带截图保存在哪里
  • win2008r2下载
  • 看linux系统
  • win8的应用商店在哪
  • 保存 linux
  • linux系统稳定
  • chm文件打不开的解决方法
  • cocos做游戏
  • unity unit
  • vim fold
  • python3正则
  • ui课程入门
  • python程序解析
  • 电子税务局下载app苹果版
  • 收讫付讫是什么意思
  • 个人限购
  • 广西的高速怎么一段收费一段不收费
  • 联合举办的活动
  • 河北省国家税务局电子税务局官网
  • 红伞伞儿歌寓意着什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设