zoukankan      html  css  js  c++  java
  • 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))
    
  • 相关阅读:
    [已解决] Python logging 重复打印日志信息
    scrapy
    Python 元编程
    MySQL性能优化 分区
    SQL Mode
    Golang 接口
    Python partial
    栈、队列(链表实现)
    Golang 位向量
    Java50题——学习以及思考
  • 原文地址:https://www.cnblogs.com/liea/p/11223702.html
Copyright © 2011-2022 走看看