这个时候就要想该怎么做才能合理的管理这些层级关系,在删除父评论的同时又能把所有子评论一起删除。查询的时候如何去由根到叶顺序输出层级关系。...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 最后,看看数据库中的记录如何
你也可以设定虚拟值的 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
当然这样的更新很麻烦,可以使用$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':
具有相同属性(特征)和方法(行为)的一系列个体的集合,类是一个抽象的概念。 什么是对象? 从类中,拿到的具有具体属性值的个体,称为对象。对象是一个具体的个体。 eg:人类;张三 类和对象的关系?...类是对象的抽象化!对象是类的具体化! 类仅仅表明这类对象有哪些属性,但是不能有具体的值,所以类是抽象的。 对象是将类的所有属性赋值后,产生具体的个体,所有对象是具体的。...// 是否允许文章类型中的文章通过 中没有指定 slug ,要想改变也很简单,只要在创建的时候传入几个参数即可,或者用上文提到的register_post_type_args这个方法来修改。...Custom Post Type在属性上更接近于Page,而非Post,更改它们的固定链接需要通过代码或插件实现。
如果需要修改指定的值,而不是替换,需要使用【修改操作符】来完成修改。... 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 数据库
那么如何创建一个 Mongoose 插件,以更清洁的方式为你进行记录并简化 API 日志? Mongoose 中的插件是什么? 在 Mongoose 中,模式是可插入的。...对象通过它们自己的方法比较,而不是通过继承的、可枚举的属性进行比较。函数和 DOM 节点则进行严格相等的比较,即使用 ===。 这里我们迭代每个对象的属性和值,并将它与旧对象进行比较。...如果当前对象的 value 不等于前一个对象中相同属性的值:base[key] 如果该值是对象本身,我们递归调用函数changes 直到它得到一个值,它最终将作为 result[key]=value 存储在...你还可以通过在架构模型中初始化它来将其用于特定架构。 const mongoose = require('mongoose') mongoose.plugin(require('....你学习了如何创建 Mongoose 插件并用它来记录 API 中的 changes。
.find({}) 可以接受一个对象作为条件参数 {属性名1:值,属性名2:值} 查询属性是指定值的文档 db.....replaceOne({查询条件},{新对象}) 替换一个符合条件的文档 默认使用新对象替换旧对象 如果需要修改指定的属性,而不是替换,需要使用“修改操作符”来完成修改 $set 可以修改文档中的指定属性...,不是物理删除 不建议使用物理删除,因为删除之后无法找回 文档的属性值可以是一个文档,当一个文档的属性值是一个文档时,我们称这个文档叫做内嵌文档 其他方法 skip((页码-1)*每页显示条数).limit...(Schema) 可以对模型中的对象/文档进行验证 数据可以通过类型转换转换为对象 可以使用中间件来应用业务逻辑挂钩 比 Node 原生的 MongoDB 驱动更容易 使用 Mongoose 使用 npm...Schema 来创建 Model // Model 代表的是数据库中的集合,通过 Model 才能对数据库进行操作 // mongoose.model(modelName, Schema); // modelName
.find({}) 可以接受一个对象作为条件参数 {属性名1:值,属性名2:值} 查询属性是指定值的文档 db..findOne({}) 用来查询集合中符合条件的第一个文档 db.....replaceOne({查询条件},{新对象}) 替换一个符合条件的文档 默认使用新对象替换旧对象 如果需要修改指定的属性,而不是替换,需要使用“修改操作符”来完成修改 db.person.update...,不是物理删除 不建议使用物理删除,因为删除之后无法找回 文档的属性值可以是一个文档,当一个文档的属性值是一个文档时,我们称这个文档叫做内嵌文档 其他方法 skip((页码-1)*每页显示条数).limit...- 商品 老师 - 学生 添加字段值为数组 11 插件操作数据库 大部分使用程序来完成数据库操作 Mongoose 让我们可以通过 Node 操作 MongoDB 模板 Mongoose 是对象文档模型...查询结果结果会通过回调函数返回,参数必选,不传没有返回值 通过 find() 查询的结果,返回的对象就是 Document,文档对象 Document 对象是 Model 的实例 doc instanceof
通常我们为 Web API 使用 RESTful 设计,REST 概念分离了 API 结构和逻辑资源,通过 Http 方法GET, DELETE, POST 和 PUT等 来操作资源。...具体如下: Representational: 数据的表现形式(JSON、XML...) state: 当前状态或者数据 transfer: 数据传输 它描述了一个系统如何与另一个交流。...上面说了这么多,下面让我们看一下如何在 Koa 中践行RESTful API最佳实践吧。...) jsonwebtoken 由于 RESTful API 提倡无状态,而 JWT 又恰巧符合这一要求,因此我们采用JWT来实现用户信息的授权与认证。...在这里主要是以用户模块的crud为例来展示下如何在 koa 中践行RESTful API最佳实践。
在 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
获取多个资源,只用一个请求; 典型的 REST API 请求多个资源时得载入多个 URL,而 GraphQL 可以通过一次请求就获取你应用所需的所有数据。...GraphQL 查询能够遍历相关对象及其字段,使得客户端可以一次请求查询大量相关数据,而不像传统 REST 架构中那样需要多次往返查询。...自定义返回类型 在实际开发中,我们返回的数据类型可能是一个对象,对象中可能既有 Int 类型的属性,也有 String 类型的值,等等,这里我们可以使用 自定义返回类型 来处理: //...省略其他 const...然后定义变量 variables ,指定属性的值,之后通过 fetch 发起请求: 获取数据 function...属性上 属性定义 定义在类型后,键值对形式 定义在参数对象 fields 属性中,值为对象,每个属性名为键名,值也是对象,其中 type属性的值为 graphql 中的属性,下面会补充 补充: fields
('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);
数据库的所有操作都是异步操作 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.接受客户端传递过来的修改信息
该 versionKey 是每个文档首次创建时,由 mongoose 创建的一个属性。包含了文档的内部修订版。此文档属性是可配置的。默认值为__v。...定义一个具有给定名称的虚拟属性,该名称可以获取/设置这个路径 索引 你可以用 schema 类型选项声明 MongoDB 的索引。 index: 布尔值,是否在属性中定义一个索引。...unique: 布尔值,是否在属性中定义一个唯一索引。 sparse: 布尔值,是否在属性中定义一个稀疏索引。...limit: 指定返回结果的最大数量 skip: 指定要跳过的文档数量 lean: 返回普通的 js 对象,而不是 Mongoose Documents。...sort修饰 在指定的位置添加元素以更新数组字段 按照指定的规则排序 限制数组大小 存储数组 options lean: true 返回普通的 js 对象,而不是 Mongoose Documents
获取多个资源,只用一个请求; 典型的 REST API 请求多个资源时得载入多个 URL,而 GraphQL 可以通过一次请求就获取你应用所需的所有数据。...GraphQL 查询能够遍历相关对象及其字段,使得客户端可以一次请求查询大量相关数据,而不像传统 REST 架构中那样需要多次往返查询。...自定义返回类型 在实际开发中,我们返回的数据类型可能是一个对象,对象中可能既有 Int 类型的属性,也有 String 类型的值,等等,这里我们可以使用 自定义返回类型 来处理: //...省略其他 const...然后定义变量 variables ,指定属性的值,之后通过 fetch 发起请求: 获取数据 function...name 属性上 属性定义 定义在类型后,键值对形式 定义在参数对象 fields 属性中,值为对象,每个属性名为键名,值也是对象,其中 type属性的值为 graphql 中的属性,下面会补充 补充
,不过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数据库中查询对应的产品
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 类的继承。
本文源自工作中的一个问题,在使用 Mongoose 做关联查询时发现使用 populate() 方法不能直接关联非 _id 之外的其它字段,在网上搜索时这块的解决方案也并不是很多,在经过一番查阅、测试之后...引用模型是一种规范化的数据模型,通过主外键的方式来关联多个文档之间的引用关系,减少了数据的冗余,在使用这种数据模型中就要用到关联查询,也就是本文我们要讲解的重点。...图片来源:mongoing[1] 引用模型示例 JSON 模型 我们通过作者和书籍的关系,一个作者对应多个书籍这样一个简单的示例来学习如何在 MongoDB 中实现关联非 _id 查询。..._id 字段,并且在 populate 方法里无法更改的,但是在 Mongoose 4.5.0 之后增加了虚拟值填充[3],以便实现文档中更复杂的一些关系。...关联查询时如何关联一个非 _id 字段,一种方式是直接使用 MongoDB 原生提供的 Aggregate 聚合管道的 lookup 阶段来实现,这种方式使用起来灵活,可操作的空间更大,例如通过 as
这里提供一个简化的、概念性的示例代码框架,以展示如何开始构建这样的系统。...后端框架(以Node.js和Express为例)首先,安装必要的依赖:bash复制代码npm install express mongoose body-parser然后,创建一个基本的服务器和数据库模型...type: mongoose.Schema.Types.ObjectId, ref: 'Order' }], // 订单 // 其他用户属性... }); // 订单模型 const...在实际应用中,必须确保所有敏感信息的安全处理。性能优化:对于大量用户和订单,需要优化数据库查询和服务器性能。业务逻辑:示例代码未实现完整的业务逻辑,如排队免单算法、奖励机制等。...这些需要根据具体需求进行详细设计和实现。前端交互:前端示例代码非常基础,实际中需要更复杂的用户交互和界面设计。测试:在实际部署之前,需要进行全面的测试,包括单元测试、集成测试、性能测试等。
app.js 中,而是根据不同的子应用(users、index)进行了拆分,这也与该系列第一篇教程[7]中 vue-router 的嵌套路由不谋而合。...接入 MongoDB 数据库 解决数据持久化存储最流行的方案无疑是数据库,而 MongoDB 凭借其优异的性能、可扩展性和灵活的数据模式,从众多数据库产品中脱颖而出。...通过定义它们来告诉 mongoose 你需要的数据结构和对应的数据类型是什么。 我们来创建 model/index.js 文件编写我们的 Schema 。...接着我们通过 model 来创建对于的数据模型,然后导出我们创建好的数据模型。这里的 model 就是经典的 MVC 设计模式中的 Model。...•使用 POSTman 来测试我们编写的 API 相信通过本篇教程的学习,你对使用 Node 和 Express 编写 API 后端服务器有了一个基本的了解,现在我们了解了 Vue 基础知识,了解了如何搭建后端服务器
领取专属 10元无门槛券
手把手带您无忧上云