首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

对博客中评论的合理建模 --MongoDB

这个时候就要想该怎么做才能合理的管理这些层级关系,在删除父评论的同时又能把所有子评论一起删除。查询的时候如何去由根到叶顺序输出层级关系。...post列中关联引用表(post表)的 _id(文章),在 hasChild 中记录是否存在回复。...当然这不是重点,通过层次命名的 key,对删除父评论相当方便。例如下图所示的关系层级。...然后删除 key 为 11#001 的评论只要使用正则匹配 /^11#001/即可,把匹配到的内容全部删除就可以不用管关联的 post 是否一致,以及 cid,而 key 的值可以从前端发起的请求中提取...d\\d\\d$`) 5 }) 6body.key = String(pid) + `#${String(comments + 1).padStart(3, 0)}` COPY 最后,看看数据库中的记录如何

55220

mongoose官方文档总结

你也可以设定虚拟值的 setter ,下例中,当你赋值到虚拟值时,它可以自动拆分到其他属性: personSchema.virtual('fullName')....Model的多个静态辅助方法都可以查询文档 Query实例有一个.then()函数,用法类似Promise 我们看一下demo,查询persons表中name中属性last为Ghost值的文档,只查询..._id); }) 异步 Post 钩子 如果你给 post 钩子的回调函数传入两个参数,mongoose 会认为第二个参数是 next()函数,可以通过 next 触发下一个中间件 schema.post...join 聚合操作,那就死$lookup,而 mongoose 拥有更强大的 populate,可以让你在别的 collection 中引用 document。...所有储存在此的_id 都必须是 Story model 中的 document 的 _id 保存 refs 保存 refs 与保存普通属性一样,把_id的值赋给他就好了 const author

20.6K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Mongoose学习参考文档

    当然这样的更新很麻烦,可以使用$set属性来配置,这样也不用先查询,如果更新的数据比较少,可用性还是很好的: PersonModel.update({_id:_id},{$set:{name:'...  如果children是parent的子文档,可以通过如下方法查询到children var child = parent.children.id(id); 4.2 新增、删除、更新   子文档是父文档的一个属性...,还具有数据库行为模型,他相当于管理数据库属性、行为的类 5.2 如何创建Model   你必须通过Schema来创建,如下: //先创建Schema var TankSchema =...6.1 查询的方式   通常有2种查询方式,一种是直接查询,一种是链式查询(2种查询都是自己命名的) 6.1.1 直接查询   在查询时带有回调函数的,称之为直接查询,查询的条件往往通过API来设定,例如...,请查询API 6.1.2 链式查询   在查询时候,不带回调,而查询条件通过API函数来制定,例如: var query = PersonModel.findOne({'name.last':

    24.2K90

    史上最详细的WordPress的自定义文章类型指南(1)

    具有相同属性(特征)和方法(行为)的一系列个体的集合,类是一个抽象的概念。 什么是对象? 从类中,拿到的具有具体属性值的个体,称为对象。对象是一个具体的个体。 eg:人类;张三 类和对象的关系?...类是对象的抽象化!对象是类的具体化! 类仅仅表明这类对象有哪些属性,但是不能有具体的值,所以类是抽象的。 对象是将类的所有属性赋值后,产生具体的个体,所有对象是具体的。...// 是否允许文章类型中的文章通过 中没有指定 slug ,要想改变也很简单,只要在创建的时候传入几个参数即可,或者用上文提到的register_post_type_args这个方法来修改。...Custom Post Type在属性上更接近于Page,而非Post,更改它们的固定链接需要通过代码或插件实现。

    4.4K20

    大数据技术之_22_MongoDB学习_MongoDB 的简介、下载、安装、启动、配置和关闭 + MongoDB 的基本操作 + Mongoose + 使用 java 对 MongoDB 增删改查

    如果需要修改指定的值,而不是替换,需要使用【修改操作符】来完成修改。... hero 的文档 // MongoDB 支持直接通过内嵌文档的属性进行查询,如果要查询内嵌文档则可以通过.的形式来匹配 // 如果要通过内嵌文档来对文档进行查询,此时属性名必须使用引号(单双引号均可)...//在查询时,可以在第二个参数的位置来设置查询结果的--即投影 db.emp.find({}, {ename: 1, _id: 0, sal: 1});  第四章 Mongoose 4.1 Mongoose...而 Mongoose 就是一个让我们可以通过 Node 来操作 MongoDB 的模块。   ..._id); // id 是 Document 对象的属性,而 _id 是 js 对象的属性     } }); 4.10 Mongoose 的模块化 1、定义一个模块,用于连接 MongoDB 数据库

    17.8K30

    用 Mongoose 插件记录Node.js API日志

    那么如何创建一个 Mongoose 插件,以更清洁的方式为你进行记录并简化 API 日志? Mongoose 中的插件是什么? 在 Mongoose 中,模式是可插入的。...对象通过它们自己的方法比较,而不是通过继承的、可枚举的属性进行比较。函数和 DOM 节点则进行严格相等的比较,即使用 ===。 这里我们迭代每个对象的属性和值,并将它与旧对象进行比较。...如果当前对象的 value 不等于前一个对象中相同属性的值:base[key] 如果该值是对象本身,我们递归调用函数changes 直到它得到一个值,它最终将作为 result[key]=value 存储在...你还可以通过在架构模型中初始化它来将其用于特定架构。 const mongoose = require('mongoose') mongoose.plugin(require('....你学习了如何创建 Mongoose 插件并用它来记录 API 中的 changes。

    2.8K40

    04_数据库

    .find({}) 可以接受一个对象作为条件参数 {属性名1:值,属性名2:值} 查询属性是指定值的文档 db.....replaceOne({查询条件},{新对象}) 替换一个符合条件的文档 默认使用新对象替换旧对象 如果需要修改指定的属性,而不是替换,需要使用“修改操作符”来完成修改 $set 可以修改文档中的指定属性...,不是物理删除 不建议使用物理删除,因为删除之后无法找回 文档的属性值可以是一个文档,当一个文档的属性值是一个文档时,我们称这个文档叫做内嵌文档 其他方法 skip((页码-1)*每页显示条数).limit...(Schema) 可以对模型中的对象/文档进行验证 数据可以通过类型转换转换为对象 可以使用中间件来应用业务逻辑挂钩 比 Node 原生的 MongoDB 驱动更容易 使用 Mongoose 使用 npm...Schema 来创建 Model // Model 代表的是数据库中的集合,通过 Model 才能对数据库进行操作 // mongoose.model(modelName, Schema); // modelName

    7010

    架构和数据库

    .find({}) 可以接受一个对象作为条件参数 {属性名1:值,属性名2:值} 查询属性是指定值的文档 db..findOne({}) 用来查询集合中符合条件的第一个文档 db.....replaceOne({查询条件},{新对象}) 替换一个符合条件的文档 默认使用新对象替换旧对象 如果需要修改指定的属性,而不是替换,需要使用“修改操作符”来完成修改 db.person.update...,不是物理删除 不建议使用物理删除,因为删除之后无法找回 文档的属性值可以是一个文档,当一个文档的属性值是一个文档时,我们称这个文档叫做内嵌文档 其他方法 skip((页码-1)*每页显示条数).limit...- 商品 老师 - 学生 添加字段值为数组 11 插件操作数据库 大部分使用程序来完成数据库操作 Mongoose 让我们可以通过 Node 操作 MongoDB 模板 Mongoose 是对象文档模型...查询结果结果会通过回调函数返回,参数必选,不传没有返回值 通过 find() 查询的结果,返回的对象就是 Document,文档对象 Document 对象是 Model 的实例 doc instanceof

    8010

    WordPress 文章查询教程1:如何使用分类,标签或其他分类模式参数

    在 WordPress 中,使用 WP_Query 进行文章查询是最常见的操作,学习好这方面的操作, WordPress 开发基本就学会了一半。...「WordPress果酱」将通过一系列教程讲解如何使用 WP_Query 进行 WordPress 文章查询。...taxonomy (string) – 分类模式. field (string) – 如何获取分类模式(Taxonomy term),可能的值有:「term_id」,「name」,「slug」或者「term_taxonomy_id...(动作片),comedy(喜剧片)并且 actor(演员)ID不是 103, 115, 206 的电影。...比如:获取在 quotes 分类中或者同时有 quote 文章格式和在 wisdom 分类中的文章: $query = new WP_Query(array( 'post_type' => 'post

    1.5K51

    【GraphQL】225-GraphQL真香入门教程

    获取多个资源,只用一个请求; 典型的 REST API 请求多个资源时得载入多个 URL,而 GraphQL 可以通过一次请求就获取你应用所需的所有数据。...GraphQL 查询能够遍历相关对象及其字段,使得客户端可以一次请求查询大量相关数据,而不像传统 REST 架构中那样需要多次往返查询。...自定义返回类型 在实际开发中,我们返回的数据类型可能是一个对象,对象中可能既有 Int 类型的属性,也有 String 类型的值,等等,这里我们可以使用 自定义返回类型 来处理: //...省略其他 const...然后定义变量 variables ,指定属性的值,之后通过 fetch 发起请求: 获取数据 function...属性上 属性定义 定义在类型后,键值对形式 定义在参数对象 fields 属性中,值为对象,每个属性名为键名,值也是对象,其中 type属性的值为 graphql 中的属性,下面会补充 补充: fields

    8.1K21

    MongoDB数据库基本操作

    ('User', userSchema); // 查询用户集合中的所有文档 User.find().then(result => console.log(result)); // 通过_id字段查找文档...默认返回当前集合中的第一条文档 // User.findOne({name: '李四'}).then(result => console.log(result)) // 查询用户集合中年龄字段大于20...字段值包含足球的文档 // User.find({hobbies: {$in: ['足球']}}).then(result => console.log(result)) // 选择要查询的字段 //...('User', userSchema); // 查找到一条文档并且删除 // 返回删除的文档 // 如何查询条件匹配了多个文档 那么将会删除第一个匹配的文档 // User.findOneAndDelete..., // 自定义错误信息 message: '传入的值不符合验证规则' } } }); const Post = mongoose.model('Post', postSchema);

    4.2K10

    MongoDB增删改查操作

    数据库的所有操作都是异步操作 1.使用create方法创建文档 通过回调函数的方法获取异步API // 向集合中插入文档 Course.create({ name: 'JavaScript',...不想要的值在字段后面添加 - 再加属性 比如去掉默认的_id User.find().select('name email -_id').then(result => console.log(result...1.5 删除文档 删除单个文档 查找到一条文档并且删除 返回删除的文档 如何查询条件匹配了多个文档那么将会删除第一个匹配的文档 User.findOneAndDelete({_id: '5c09f1e5aeb04b22f8460965...使用ID将文章集合和作者集合进行关联 author: { type: mongoose.Schema.Types.ObjectId, ref: 'User' } })); //联合查询 Post.find...将用户ID传递到当前页面 2.从数据库中查询当前用户信息 将用户信息展示到页面中 2.实现用户修改功能 1.指定表单的提交地址以及请求方式 2.接受客户端传递过来的修改信息

    19.9K30

    你真的了解mongoose吗?

    该 versionKey 是每个文档首次创建时,由 mongoose 创建的一个属性。包含了文档的内部修订版。此文档属性是可配置的。默认值为__v。...定义一个具有给定名称的虚拟属性,该名称可以获取/设置这个路径 索引 你可以用 schema 类型选项声明 MongoDB 的索引。 index: 布尔值,是否在属性中定义一个索引。...unique: 布尔值,是否在属性中定义一个唯一索引。 sparse: 布尔值,是否在属性中定义一个稀疏索引。...limit: 指定返回结果的最大数量 skip: 指定要跳过的文档数量 lean: 返回普通的 js 对象,而不是 Mongoose Documents。...sort修饰 在指定的位置添加元素以更新数组字段 按照指定的规则排序 限制数组大小 存储数组 options lean: true 返回普通的 js 对象,而不是 Mongoose Documents

    41.6K30

    GraphQL真香入门教程

    获取多个资源,只用一个请求; 典型的 REST API 请求多个资源时得载入多个 URL,而 GraphQL 可以通过一次请求就获取你应用所需的所有数据。...GraphQL 查询能够遍历相关对象及其字段,使得客户端可以一次请求查询大量相关数据,而不像传统 REST 架构中那样需要多次往返查询。...自定义返回类型 在实际开发中,我们返回的数据类型可能是一个对象,对象中可能既有 Int 类型的属性,也有 String 类型的值,等等,这里我们可以使用 自定义返回类型 来处理: //...省略其他 const...然后定义变量 variables ,指定属性的值,之后通过 fetch 发起请求: 获取数据 function...name 属性上 属性定义 定义在类型后,键值对形式 定义在参数对象 fields 属性中,值为对象,每个属性名为键名,值也是对象,其中 type属性的值为 graphql 中的属性,下面会补充 补充

    7.3K30

    在Express中对MongoDB数据库进行增删改查

    ,不过Rest-Client插件可以直接在VSCode中发送HTTP的GET、POST、PUT、DELETE请求,对于开发人员来说很方便,具体可以参考Johnny老师的B站视频VSCode中类似PostMan...的API接口请求利器 - rest client,这篇视频快速的讲解了VSCode中Rest-Client的使用,具体的还可以看VSCode中Rest-Client的使用教程。...赋值给产品(赋值不需要异步,因为它只是javascript中的一个内存操作,而查询、保存数据都需要和MongoDB连接需要异步) product.title = req.body.title;...赋值给产品(赋值不需要异步,因为它只是javascript中的一个内存操作,而查询、保存数据都需要和MongoDB连接需要异步) product.title = req.body.title;...号删除某个产品 app.delete('/products/:id', async function(req, res){ // 根据客户端传递过来的id从MongoDB数据库中查询对应的产品

    5.3K10

    使用 NextJS 和 TailwindCSS 重构我的博客

    id 获取文章详情 export async function getStaticProps({ params }) { // 如果页面的路由是 /posts/1, 这 params.id 的值就是...prisma —— 下一代 ORM 框架 Nodejs 框架访问数据库,往往会需要一个 ORM 框架来帮我们管理数据层代码,而在 Node.js 社区中,sequelize、TypeORM 等框架都被广泛应用...Prisma 是一种新的 ORM,它缓解了传统 ORM 的许多问题,例如: 模型实例的膨胀、业务与存储逻辑的混合、缺乏类型安全性或由延迟加载引起的不可预测查询。...@relation(fields: [authorId], references: [id]) } Schema 是一个描述文件,描述了数据模型直接的关系,再通过prisma generate 生成 typescript...@Entity()来实现 JavaScript 类的继承。

    2.4K20

    Mongoose 实现关联查询和踩坑记录

    本文源自工作中的一个问题,在使用 Mongoose 做关联查询时发现使用 populate() 方法不能直接关联非 _id 之外的其它字段,在网上搜索时这块的解决方案也并不是很多,在经过一番查阅、测试之后...引用模型是一种规范化的数据模型,通过主外键的方式来关联多个文档之间的引用关系,减少了数据的冗余,在使用这种数据模型中就要用到关联查询,也就是本文我们要讲解的重点。...图片来源:mongoing[1] 引用模型示例 JSON 模型 我们通过作者和书籍的关系,一个作者对应多个书籍这样一个简单的示例来学习如何在 MongoDB 中实现关联非 _id 查询。..._id 字段,并且在 populate 方法里无法更改的,但是在 Mongoose 4.5.0 之后增加了虚拟值填充[3],以便实现文档中更复杂的一些关系。...关联查询时如何关联一个非 _id 字段,一种方式是直接使用 MongoDB 原生提供的 Aggregate 聚合管道的 lookup 阶段来实现,这种方式使用起来灵活,可操作的空间更大,例如通过 as

    26.5K20

    城市X选与 2+1 拼购模式:循环社交裂变,促进用户增长

    这里提供一个简化的、概念性的示例代码框架,以展示如何开始构建这样的系统。...后端框架(以Node.js和Express为例)首先,安装必要的依赖:bash复制代码npm install express mongoose body-parser然后,创建一个基本的服务器和数据库模型...type: mongoose.Schema.Types.ObjectId, ref: 'Order' }], // 订单 // 其他用户属性... }); // 订单模型 const...在实际应用中,必须确保所有敏感信息的安全处理。性能优化:对于大量用户和订单,需要优化数据库查询和服务器性能。业务逻辑:示例代码未实现完整的业务逻辑,如排队免单算法、奖励机制等。...这些需要根据具体需求进行详细设计和实现。前端交互:前端示例代码非常基础,实际中需要更复杂的用户交互和界面设计。测试:在实际部署之前,需要进行全面的测试,包括单元测试、集成测试、性能测试等。

    11510

    从零到部署:用 Vue 和 Express 实现迷你全栈电商应用(二)

    app.js 中,而是根据不同的子应用(users、index)进行了拆分,这也与该系列第一篇教程[7]中 vue-router 的嵌套路由不谋而合。...接入 MongoDB 数据库 解决数据持久化存储最流行的方案无疑是数据库,而 MongoDB 凭借其优异的性能、可扩展性和灵活的数据模式,从众多数据库产品中脱颖而出。...通过定义它们来告诉 mongoose 你需要的数据结构和对应的数据类型是什么。 我们来创建 model/index.js 文件编写我们的 Schema 。...接着我们通过 model 来创建对于的数据模型,然后导出我们创建好的数据模型。这里的 model 就是经典的 MVC 设计模式中的 Model。...•使用 POSTman 来测试我们编写的 API 相信通过本篇教程的学习,你对使用 Node 和 Express 编写 API 后端服务器有了一个基本的了解,现在我们了解了 Vue 基础知识,了解了如何搭建后端服务器

    3.1K10
    领券