• mongodb数据库的集合关联


    通常不同集合的数据之间是有关系的,例如文章和用户信息存储在不同的集合中,但是文章时某个用户发表的,要查询文章的所有信息包括发表用户,就需要用到集合关联。

    文章集合 用户集合
    _id _id
    title name
    author age

    content

    hobbies

    示例:

    const mongoose = require('mongoose')
    
    mongoose.connect('mongodb://localhost/test1', { useNewUrlParser: true })
      .then(() => console.log('数据库连接成功'))
      .catch(err => console.log('数据连接失败' + err))
    
    // 文章集合规则
    const PostSchema = new mongoose.Schema({
      title: String,
      content: String,
      author: {
        type: mongoose.Schema.Types.ObjectId,
        ref: 'User'
      }
    })
    
    // 用户集合规则
    const UserSchema = new mongoose.Schema({
      name: String,
      age: Number,
      hobbies: String
    })
    
    // 文章集合
    const post = mongoose.model('Post', PostSchema)
    // 用户集合
    const user = mongoose.model('User', UserSchema)
    
    // 创建用户
    user.create({ name: 'zhangsan', age: 20, hobbies: '11111' })
      .then(res => console.log(res))
      .catch(err => console.log(err))
    
    // // 创建文章
    post.create({ title: '测试测试', content: '内容内容内容内容', author: '5d34f0542fdc3f7924249a9c' })
      .then(res => console.log(res))
      .catch(err => console.log(err))
    
      // 查询
    post.find().populate('author').then(res => console.log(res))
    
  • 相关阅读:
    MySQL函数大全
    Hibernate的理论知识点
    捕获异常
    重定向到其他的页面
    Jquery中val、text、html的区别
    条件注释判断浏览器<!--[if !IE]><!--[if IE]><!--[if lt IE 6]><!--[if gte IE 6]>
    inline-block元素的4px空白间距解决方案
    img标签中alt属性与title属性
    3像素文本偏移bug 解决方案
    google Ip
  • 原文地址:https://www.cnblogs.com/liea/p/11223702.html
Copyright © 2020-2023  润新知