: 5c09dea28acfb814980ff827, name: 'Javascript', author: 'wuyuxin‘ }] // 根据条件查找文档 Course.findOne...第三方模块 用来操作数据库 const mongoose = require('mongoose'); // 数据库连接 mongoose.connect('mongodb://localhost/playground...// User.find({_id: '5c09f267aeb04b22f8460968'}).then(result => console.log(result)) // findOne方法返回一条文档...默认返回当前集合中的第一条文档 // User.findOne({name: '李四'}).then(result => console.log(result)) // 查询用户集合中年龄字段大于20...限制显示3条结果 User.find().skip(2).limit(3).then(result => console.log(result)) 图依次为为1-5的执行结果 image.png image.png
limit: 指定返回结果的最大数量 skip: 指定要跳过的文档数量 lean: 返回普通的 js 对象,而不是 Mongoose Documents。...如果出错,则 error 是出错信息,result 是 null;如果查询成功,则 error 是 null, result 是查询结果,查询结果的结构形式是根据查询方法的不同而有不同形式的。...find() 方法的查询结果是数组,即使没查询到内容,也会返回 [] 空数组。...而 findById(undefined) 相当于 findOne({ _id: null }),返回 null。 查询结果: 返回数据的格式是 {} 对象形式。...findOne 该方法返回查找到的所有实例的第一个 Model.findOne(conditions, [projection], [options], [callback]) 如果查询条件是 _id
,document有自带的实例方法,当然也可以自定义我们自己的方法。...、findbyId,findOne,和where这些静态方法。...handler(err) }) 更新 model 的 update 方法可以修改数据库中的文档,不过不会把文档返回给应用层。...如果想更新单独一条文档并且返回给应用层,可以使用 findOneAndUpdate 方法。 六、文档-Documents Mongoose document代表着MongoDB文档的一对一映射。...返回的一切对象: const mongoose = require('mongoose') const Schema = mongoose.Schema; const personSchema =
实际在数据库中产生的集合名为courses 2.创建文档 创建文档实际上就是向集合中插入数据。 方法1 分为两步: ①创建集合实例。 ②调用实例对象下的save方法将数据保存到数据库中。...4.查询文档 find()方法 返回一组文档 // 根据条件查找文档(条件为空则查找所有文档) Course.find().then(result => console.log(result)) //..._id: 5c09dea28acfb814980ff827, name: 'Javascript', author: 'xc-dh‘ }] findOne()方法 返回一条文档...// 根据条件查找文档 Course.findOne({name: 'node.js基础'}).then(result => console.log(result)) // 返回文档 只返回一条,默认返回第一条...})); // 2、联合查询 Post.find().populate('author').then(result => { console.log(result); }) // 返回结果如下
name: 'node.js基础', author: '一客', isPublished: true }); //将文档插入数据库中 course.save(); 通过集合构造函数方法...// User.find({_id: '5c09f267aeb04b22f8460968'}).then(result => console.log(result)) // findOne方法返回一条文档...默认返回当前集合中的第一条文档 // User.findOne({name: '李四'}).then(result => console.log(result)) // 查询用户集合中年龄字段大于20...('User', userSchema); // 查找到一条文档并且删除 // 返回删除的文档 // 如何查询条件匹配了多个文档 那么将会删除第一个匹配的文档 // User.findOneAndDelete...('User', userSchema); // 找到要删除的文档并且删除 // 返回是否删除成功的对象 // 如果匹配了多条文档, 只会删除匹配成功的第一条文档 // User.updateOne({
本文源自工作中的一个问题,在使用 Mongoose 做关联查询时发现使用 populate() 方法不能直接关联非 _id 之外的其它字段,在网上搜索时这块的解决方案也并不是很多,在经过一番查阅、测试之后...$lookup.foreignFiled: 被 Join 的集合的字段,本示例中是 Books 表的 bookId 字段。 $as: 别名,关联查询返回的这个结果起一个新的名称。...实现 Mongoose 的 populate 方法默认情况下是指向的要关联的集合的 _id 字段,并且在 populate 方法里无法更改的,但是在 Mongoose 4.5.0 之后增加了虚拟值填充...表示的要 Join 的集合的名称,同 $lookup.from justOne: 默认为 false 返回多条数据,如果设置为 true 就只会返回一条数据 AuthorSchema.virtual('...另外一种是 Mongoose 提供的 populate 方法,这种方式写起来,代码会更简洁些,这里需要注意如果关联的字段是非 _id 字段,一定要在 Schema 中设置虚拟值填充,否则 populate
,Nest 官方为我们提供了一个 Mongoose 的封装,我们需要安装 mongoose 和 @nestjs/mongoose: npm install mongoose @nestjs/mongoose...,负责处理客户端传入的请求和服务端返回的响应。...的路由,这个路由负责返回所有的用户信息。...当然,也可以把 findAll 方法写成异步方法,像这样: // user.controller.ts import { Controller, Get } from '@nestjs/common';...Model,这样才能在类中的方法里操作数据库。
实际在数据库中产生的集合名为courses 1.创建文档 创建文档实际上就是向集合中插入数据。 方法1 分为两步: ①创建集合实例。 ②调用实例对象下的save方法将数据保存到数据库中。...在项目根目录下输入以下命令导入 mongoimport -d 数据库名称 -c 集合名称 --file 要导入的数据文件 4.查询文档 find()方法 返回一组文档 // 根据条件查找文档(条件为空则查找所有文档...()方法 返回一条文档 // 根据条件查找文档 Course.findOne({name: 'node.js基础'}).then(result => console.log(result)) // 返回文档...使用id对集合进行关联 使用populate方法进行关联集合查询 // 关联集合 const mongoose = require('mongoose'); // 连接数据库 mongoose.connect...})); // 2、联合查询 Post.find().populate('author').then(result => { console.log(result); }) // 返回结果如下
查询一个符合条件的文档对象的属性值(该方法常用) db.users.findOne({age:25}).length(); // 查询一个符合条件的文档对象的属性值(该方法不常用) 删除文档 db.collection.remove...//在查询时,可以在第二个参数的位置来设置查询结果的--即投影 db.emp.find({}, {ename: 1, _id: 0, sal: 1}); 第四章 Mongoose 4.1 Mongoose...查询的方法: Model.find(conditions, [projection], [options], [callback]) - 查询所有符合条件的文档,总会返回一个数组...options 查询选项(常用 skip、limit) 示例:{skip: 3, limit: 1} callback 回调函数,查询结果会通过回调函数返回...err) { // console.log(doc); // 通过 find() 查询的结果,返回的对象就是 Document 对象或 Document 对象数组。
一,先定义了一个goods(商品)的models var mongoose = require('mongoose'); var Schema = mongoose.Schema; var productSchema...(我们默认是可以直接添加的)===>userDoc为登录后的用户,我们为此用户的购物车添加商品 我们goods路由中: Goods.findOne({...因为Mongoose是個ODM (Object Document Mapper),类似于操作关系型数据库使用的ORM(Object Relational Mapper),我们使用Mongoose取到的数据的结构是要依赖于我们定义的...结论:mongodb中使用mongoose取到的对象不能增加属性。 解决方法一, 在schema中直接增加需要补充的属性。...(有时候不是很好) 解决方法二, 把查询到的结果clone一个对象,然后在新对象中补充属性。
增加MongoDB连接方法 config/db.js: const mongoose = require('mongoose'); const config = require('config'); const...models/url.js: const mongoose = require('mongoose'); const urlSchema = new mongoose.Schema({ urlCode...生成短链接编码 这是我们实现的关键一步,思路是:用户传入一个长链接,我们首先使用 valid-url 判断传入的url是否合法,不合法则返回错误,如果合法我们在数据库中搜索是否有该长链接的记录,如果有则直接返回该条记录...访问短链接跳转到原链接 最后一步非常简单,当用户访问我们生成的短链接时,我们根据url中的短链接编码查询到对应记录,如果存在对应记录我们使用express的res.redirect方法将访问重定向至原链接...,如果不存在则返回错误。
; const book = mongoose.model("book"); // 获取上一篇和下一篇的文章 // select是指定返回的字段 let prevBook = await... book .findOne({ ID: { $lt: bookId }, visible: true }) .sort({ ID: -1 }) .select({ ID: 1,... title: 1 }) .then((res) => res); let nextBook = await book .findOne({ ID: { $gt: bookId },...}) .sort({ ID: 1 }) .select({ ID: 1, title: 1 }) .then((res) => res); await book .findOne...: 在find的条件中 不匹配某个结果 let boardMsgLength = await messageBoard.find({ from: "留言板" }).count(); //匹配留言板的数量
MongoDB是一款流行的文档型数据库,可以在Node.js中使用官方的MongoDB包或者第三方包mongoose进行操作。..., callback);其中,filter 表示查询条件,update 表示更新操作,projection 表示指定返回的字段,options 表示查询选项,callback 表示回调函数。...发布 Model 时,需要将 Schema 传入 mongoose.model() 方法中,生成集合(表)的构造函数。...在查询数据时,可以通过 Model 对象进行查询,例如 find() 方法查询所有数据、findOne() 方法查询单个数据等。...同时,使用MongoDB数据库需要注意的是,我们需要在Node.js中使用mongoose.connect或者mongodb.MongoClient.connect方法来连接数据库,然后才能对数据库进行操作
); } else { //如果用户不存在 添加此条数据到数据库 const newUser = await User.create(req.body); //返回插入的数据...return res.send(newUser); } }); 在 postman 中测试结果如下 可以成功返回插入的数据 13.在 app.js 中配置 cors 解决跨域问题...$axios = axios 5.在 Register.vue 中验证方法中使用 axios 发送请求 methods: { submitForm(formName) { this....$router.push('/index'); }) 再次测试结果如下 跳转到 index 页面并提示用户注册成功 8.用户已经存在的错误验证 服务器端 register.js 代码修改如下...}) } else { //如果用户不存在 添加此条数据到数据库 const newUser = await User.create(req.body); //返回结果
这里的mongoose就是npm的一个包,主要是为程序提供连接mongodb并增删查改的功能。...由于我们生成短链接部分的api使用的是post方法,使用body-parser可以多扩展一种body编码类型解析能力。...: var objurl = { shortUrl: shortid, longUrl: url}; 最后,连接数据库并保存后将短链接结果返回客户端: mongoose.connect(setup.mongo_db...(setup.mongo_db, setup.mongo_options); UrlTable.findOne({ shortUrl:shortUrl }).then((result) => {...); UrlTable.findOne({ shortUrl:shortUrl }).then((result) => { //待添加错误处理 res.redirect
/common/img/logo.png" alt=""> mongoose 操作mongodb的 npm i mongoose --save 就不一一列举所有的插件了(没有用vuex) 开发上的一些事...,Student.register); // 学生登录 app.post('/api/studentlogin', Student.signup); .... } 可以看到,我将每个路由的方法都是提取出去的...在此将一些数据库增删改查的方法回顾一下。...初始化一条数据 如果对mongodb,mongoose没有基础的了解,建议看一看mongoose深入浅出 ,mongoose基础操作 // controllers/student.js const...,但是有很多时候不同的集合直接是需要关联的,这是就用到了mongoose提供的populate 直接看图,不同集合直接的关联,用的就是_id,比如下图中,学生参加的考试,关联了试卷,试卷里面又关联了题目
实现查询数据 对于MongoDB Native Node.js Driver来说有四种查询数据的方法:find()、findOne()、findAndRemove()、findAndModify() ...这些选项值我们同样可以在mongo下使用,进行数据的一些操作 1、接下来我们来用find()查询并返回我们数据库的内容,可以直接使用toArray()方法将结果转化为数组 2、使用可选值field来进行筛选...但是需要注意的一点是,我们设置为1,也并不是只出现type字段,系统生成的唯一标识符也就是_id总是会出现在查询结果中 更新、删除文档 修改、删除文档的方法:更新文档:update() 或者是upserts...(如果不存在就添加文档),删除文档remove()、查找并修改或者删除一个文档findAndModify()、查找并删除一个文档findAndRemove() update/remove和后两个方法之间最本质的区别就在于后者两个方法都返回了被操作的文档...下一次我会总结一下使用express + mongoose建立数据库的连接
,相关内容请查看NodeJS-API 1.6 关于Mixed Schema.Types.Mixed是Mongoose定义个混合类型,该混合类型如果未定义具体形式。...第二个参数是更新的数量,如果要返回更新后的对象,则要使用如下方法 Person.findByIdAndUpdate(_id,{$set:{name:'MDragon'}},function(err...remove方法 4.Sub Docs 如同SQL数据库中2张表有主外关系,Mongoose将2个Document的嵌套叫做Sub-Docs(子文档) 简单的说就是一个Document嵌套另外一个...,只能用自己的方法。...,如果不带callback,则返回query,query没有执行的预编译查询语句,该query对象执行的方法都将返回自己,只有在执行exec方法时才执行查询,而且必须有回调。
调用实例对象下的save方法将数据保存到数据库中。...数据库的所有操作都是异步操作 1.使用create方法创建文档 通过回调函数的方法获取异步API // 向集合中插入文档 Course.create({ name: 'JavaScript',...{ console.log(err); }) .catch(result => { console.log(result); }) create方法能够返回...mongoimport –d 数据库名称 –c 集合名称 –file 要导入的数据文件 显示如下结果表示导入文件成功: ? 显示如下结果表示导入文件成功: ?...// 根据条件查找文档 Course.findOne({name: 'node.js基础'}).then(result => console.log(result)) 返回一个对象 ?
1.路由模块的核心,一个路由处理一个逻辑 2.res.end / send / render 后面再写逻辑也不会执行了,因为已经返回响应。...2.限制对象一旦生成那么无法改变,除非删除数据库 3.限制对象的增删改查都返回的是一个promise对象, 如果这时候去 if() 里判断,无论有什么样的结果,都是true, 而且这个 CRUD 操作都是异步...,所以我们把外部函数变成 async 函数, 这样可以配合 await 实现最佳异步,还可以获取他们的返回值进行 if 判断。...= require('mongoose'); module.exports = new Promise((resolve, reject) => { mongoose.connect('mongodb...content="ie=edge"> Document 欢迎来到个人中心 返回主页
领取专属 10元无门槛券
手把手带您无忧上云