mongoose基本增删改查
1.安装
打开命令行
npm i mongoose
2.连接数据库
// 引入安装的包
var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/mongoo');
//mongoo这里是代表数据库的名称
var db = mongoose.connection;
db.on('error', console.error.bind(console, '连接失败'));
db.once('open', function() {
console.log('连接成功')
});
// new一个schema:把一个本身非结构化的数据变成结构化
var kittySchema = new mongoose.Schema({
name: String,
age:Number,
gender:String
});
// 根据schema得到一个model,这个model是一个class
var Kitten = mongoose.model('Kitten', kittySchema);
3.增加数据
var felyne = new Kitten({ name: '王富贵',age:18,gender:'男' });
felyne.save(function (err, res) {
//回调第一个参数代表出错
if (err) return console.error(err);
//第二个带个成功的回调参数
console.log(res)
});
添加数据的方式有两种一种是userTest.save()需要实例化模型,另一种是user.create(data,callback(err,res))这种方式不用实例化模型。
4.删除数据
Kitten.remove({name:"王富贵"},function(arr,res){
console.log(res)
})
//执行完成出现这样的代码
//{ n: 1, ok: 1, deletedCount: 1 }
// n:条件匹配到的数据条数
// ok: 1代表语句执行成功
// deletedCount: 被删除的数量
此方法将删除命令直接发送到MongoDB,不涉及Mongoose文档。由于不涉及Mongoose文档,因此不会执行任何中间件(挂钩)
Kitten.deleteOne({name:"王富贵"},function(arr,res){
console.log(res)
})
//此方法和remove类似,最多删除一个文档
此方法和remove类似,最多删除一个文档
Kitten.deleteMany({name:"王富贵"},function(arr,res){
console.log(res)
})
//此方法和remove类似,从集合中删除所有匹配的文档
此方法和remove类似,从集合中删除所有匹配的文档
5.更新数据(改数据)
Kitten.update({name:"王富贵"},{$set:{age:26}},function(arr,res){
console.log(res)
})
//update 只匹配查找到的第一条数据并进行更换
update 只匹配查找到的第一条数据并进行更换
Kitten.updateMany({name:"王多余"},{$set:{age:26}},function(arr,res){
console.log(res)
})
//updateMany 匹配查找到的所有document并更改
updateMany 匹配查找到的所有document并更改
Kitten.updateOne({name:"王多余"},{$set:{age:36}},function(arr,res){
console.log(res)
})
//updateOne 更新匹配的第一个文档
findByIdAndUpdate 根据id查找然后修改
Kitten.findByIdAndUpdate(id,{name:"王多余"},{new:true},function(arr,res){
console.log(res)
})
//findByIdAndUpdate 根据id查找然后修改
//第一个参数必须为id
//第二个参数是需要修改的内容
//第三个参数代表返回的数据是否为更新后 true为是。默认为flast。可不写
//回调 异步代码
6.查找数据
Kitten.find({},function(err,res){
console.log(res)
})
//查找数据库中所有数据
Kitten.find({name:'王富贵'},function(err,res){
console.log(res)
})
//查找所有名字为王富贵的数据
Kitten.findOne({name:'王富贵'},function(err,res){
console.log(res)
})
//查找第一个名字为王富贵的数据
Kitten.findById({_id:'5e5b43db4464113f1843e380'},function(err,res){
console.log(res)
})
//根据id查找对应的数据
查询有三种方式find查全部符合要求,findOne查到的第一个,findById通过集合中每条数据特定的_id来查询
查询方式还可以特定条件来查找
//"$lt"(小于)
//"$lte"(小于等于)
//"$gt"(大于)
//"$gte"(大于等于)
//"$ne"(不等于)
Kitten.find({age: {$ne: 18}},function (err,res) {
console.log(res)
//查找age不等于18的数据
})
范围查找
// "$in"
// "$nin"
Kitten.find({age: {$nin: [20,24]}},function (err,res) {
console.log(res)
//查找age不为20-24之间的数据
})
// "$in"查找20-24之间的数据
// "$nin"查找不为20-24之间的数据
or
Kitten.find({$or: [{name:'老王'},{name:'王富贵'}]},function (err,res) {
console.log(res)
//查找符合name为老王或者为王富贵的数据
})
增加数据中的save()要实例化model,其他皆可不用实例化model
mongoose基本增删改查的更多相关文章
- mongoDB 学习笔记纯干货(mongoose、增删改查、聚合、索引、连接、备份与恢复、监控等等)
最后更新时间:2017-07-13 11:10:49 原始文章链接:http://www.lovebxm.com/2017/07/13/mongodb_primer/ MongoDB - 简介 官网: ...
- 【转】mongoDB 学习笔记纯干货(mongoose、增删改查、聚合、索引、连接、备份与恢复、监控等等)
mongoDB 学习笔记纯干货(mongoose.增删改查.聚合.索引.连接.备份与恢复.监控等等) http://www.cnblogs.com/bxm0927/p/7159556.html
- mongoDB (mongoose、增删改查、聚合、索引、连接、备份与恢复、监控等等)
MongoDB - 简介 官网:https://www.mongodb.com/ MongoDB 是一个基于分布式文件存储的数据库,由 C++ 语言编写,旨在为 WEB 应用提供可扩展的高性能数据存储 ...
- 手把手教你基于koa2,mongoose实现增删改查
初始化项目 npm init -y 先安装一波乱七八糟的依赖插件(需要具备一定的koa2知识,至于mongoDB自行百度安装教程),模板引擎我使用的是art-template(据说是性能最好的,而且是 ...
- 基于mongoose 的增删改查操作
无论是基于robomongo 的可视化工具,亦或是基于 mongoose 的函数工具,只要是对 mongodb 的操作,第一步都是开启数据库. 开启mongodb 数据库 进入mongod所在目录 执 ...
- 使用Mongoose类库实现简单的增删改查
使用Mongoose类库实现简单的增删改查 Mongoose是在nodejs环境中对MongoDB数据库操作的封装,一种对象模型工具,可以将数据库中的数据转换为javascript对象供我们使用. M ...
- node-express项目的搭建并通过mongoose操作MongoDB实现增删改查分页排序(四)
最近写了一个用node来操作MongoDB完成增.删.改.查.排序.分页功能的示例,并且已经放在了服务器上地址:http://39.105.32.180:3333. Mongoose是在node.js ...
- Node.js、express、mongodb 入门(基于easyui datagrid增删改查)
前言 从在本机(win8.1)环境安装相关环境到做完这个demo大概不到两周时间,刚开始只是在本机安装环境并没有敲个Demo,从周末开始断断续续的想写一个,按照惯性思维就写一个增删改查吧,一方面是体验 ...
- 详解node + mongoDb(mongoDb安装、运行,在node中连接、增删改查)
一.序言 好久没写博客了,这次主要聊聊 node 和 mongoDb . 先说明一下技术栈 node + express + mongoose + mongoDb.这篇博客,主要讲述 mongoDb ...
随机推荐
- The Mean of the Sample Mean|Standard Deviation of the Sample Mean|SE
7.2 The Mean and Standard Deviation of the Sample Mean Recall that the mean of a variable is denote ...
- 史无前例的KDD 2014大会记
2014大会记" title="史无前例的KDD 2014大会记"> 作者:蒋朦 微软亚洲研究院实习生 创造多项纪录的KDD 2014 ACM SIGKDD 国际会 ...
- python 3新式类的多继承
因为我用的是python3,所以所用到的类都是新式类,这里我说的都是新式类,python2类的继承复杂一些,主要有新式类和老式类.python3类(新式类)的继承是是广度优先(BFS),实例如下: c ...
- zabbix配置文件详解--服务(server)端、客户(agent)端、代理(proxy)端
在zabbix服务(server)端.客户(agent)端.代理(proxy)端分别对应着一个配置文件,即:zabbix_server.conf,zabbix_agentd.conf,zabbix_p ...
- <JZOJ5943>树
一开始t了五个点我就一脸懵逼 然后 发现高级操作... 就是那个tor的数组2333 可以让一些不需要改的不再去改啦 位运算果然是神奇的东西XD 魔性哈哈哈 #include<cstdio> ...
- Java日期时间API系列12-----Jdk8中java.time包中的...
package com.xkzhangsan.time.test; import java.time.LocalDateTime;import java.util.Date; import com.x ...
- mysql获取按日期排序获取最新的记录
今天让一个数据查询难了.主要是对group by 理解的不够深入.才出现这样的情况 这种需求,我想很多人都遇到过.下面是我模拟我的内容表 我现在需要取出每个分类中最新的内容 select * from ...
- 18.09.22模拟赛T2 历史
网上基本上找不到这道题,何况LJJ还稍微改了一下...... 原题:传送门 题目描述 ljj 被S 国数不清的漂亮小姐姐所吸引,为了搞清楚为什么S 国有如此多的漂亮小姐姐,他决定研究S 国的历史. 根 ...
- YY孵化虎牙,陌陌收购探探:你更看好谁?
近日欢聚时代公布了2017第四季财报和全年财报,表现不错.其CFO 金秉表示,虎牙最近向美国证券交易委员会(SEC)提交了注册上市申请书草案文件,可能会在美国IPO上市,以便获取自己的投资者群体以融资 ...
- 在腾讯云centos7.2上安装配置Node.js记录
应为爱好前端所以打算在腾讯云服务器上安装JavaScript引擎Node.js,下面是安装步骤: 安装准备: 下载node.js的.tar.xz安装包:https://nodejs.org/dist/ ...