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))
    
  • 相关阅读:
    第一节:RestfulCRUD案例
    第三节:<mvc:annotationdriven />标签解析
    第二节:SpringMVC 的表单标签
    第一节:SpringMVC—数据绑定流程分析
    第四章:(2)Web开发 之 webjars&静态资源映射规则
    第三节:处理静态资源
    10.05
    四则运算二柱子1
    10.08
    10.02
  • 原文地址:https://www.cnblogs.com/liea/p/11223702.html
Copyright © 2011-2022 走看看