基于mongoose 的增删改查操作
无论是基于robomongo 的可视化工具,亦或是基于 mongoose 的函数工具,只要是对 mongodb 的操作,第一步都是开启数据库。
开启mongodb 数据库
进入mongod所在目录 执行命令 ./mongod --dbpath=存放数据的位置
例1:./mongod --dbpath d:\MongoDB\db
例2:./mongod --dbpath d:\MongoDB\db --port 自定义端口号,默认27017(了解即可,不推荐使用,修改默认端口号后期维护麻烦)
新增数据
let mongoose = require('mongoose');
let log = console.log.bind(console);
let db = null;
let Schema = mongoose.Schema;
// 链接数据库
mongoose.connect('mongodb://localhost/fay');
db = mongoose.connection;
db.on('error', console.error.bind(console, 'connection error:'))
db.once('open', (cb) => {
// 设置数据库类型
let PersonSchema = new Schema({
name: {
type: 'String',
required: true
},
age: {
type: 'Number',
retuired: true
}
});
// 新建集合(如存在该集合,就选中)
let PersonModel = db.model('person', PersonSchema);
// 需要保存的数据
let data = {
age: 50,
name: 'leno'
};
// 实例化集合并插入数据
let personEntity = new PersonModel(data);
// 保存实例
personEntity.save((err, res) => {
if(err) return log(err);
db.close();
});
})
删除数据
let mongoose = require('mongoose');
let log = console.log.bind(console);
let db = null;
let Schema = mongoose.Schema;
// 链接数据库
mongoose.connect('mongodb://localhost/fay');
db = mongoose.connection;
db.on('error', console.error.bind(console, 'connection error:'))
db.once('open', (cb) => {
// 设置数据库类型
let PersonSchema = new Schema({
name: {
type: 'String',
required: true
},
age: {
type: 'Number',
retuired: true
}
});
// 选择集合(如不存在该集合,就新建)
let PersonModel = db.model('person', PersonSchema);
// 删除的条件
let del = {name: 'leno'};
// 删除命令
PersonModel.remove(del, (err, res) => {
if(err) throw new Error(err);
log(res);
db.close();
})
});
修改数据
let mongoose = require('mongoose');
let log = console.log.bind(console);
let db = null;
let Schema = mongoose.Schema;
// 链接数据库
mongoose.connect('mongodb://localhost/fay');
db = mongoose.connection;
db.on('error', console.error.bind(console, 'connection error:'))
db.once('open', (cb) => {
// 设置数据库类型
let PersonSchema = new Schema({
name: {
type: 'String',
required: true
},
age: {
type: 'Number',
retuired: true
}
});
// 选择集合(如不存在该集合,就新建)
let PersonModel = db.model('person', PersonSchema);
// 旧数据
let oldVal = {name: 'leno'};
// 新数据
let newVal = {name: 'liao'};
// 多个新数据
let newVal2 = {name: 'liao', age: '25'};
// 修改(更新)命令
PersonModel.update(oldVal, newVal, (err, res) => {
if(err) throw new Error(err);
log(res);
db.close();
});
})
查询数据
let mongoose = require('mongoose');
let log = console.log.bind(console);
let db = null;
let Schema = mongoose.Schema;
// 链接数据库
mongoose.connect('mongodb://localhost/fay');
db = mongoose.connection;
db.on('error', console.error.bind(console, 'connection error:'))
db.once('open', (cb) => {
// 设置数据库类型
let PersonSchema = new Schema({
name: {
type: 'String',
required: true
},
age: {
type: 'Number',
retuired: true
}
});
// 选择集合(如不存在该集合,就新建)
let PersonModel = db.model('person', PersonSchema);
// 查询条件
let sql = {name: 'liao'};
// 查询命令
PersonModel.find(sql, (err, res) => {
if(err) throw new Error(err);
log(res);
db.close();
});
});
追加字段
在已存在的集合中,添加新的字段。schema.add()
基于mongoose 的增删改查操作的更多相关文章
- TP5.1:数据库的增删改查操作(基于面向对象操作)
我们现实中对数据库的增删改查操作,都是使用模型类进行操作的(表名::),也就是面向对象操作,只有底层的代码用的是数据库操作(Db::table('表名')) 下面我将贴出模型类进行的增删改查操作,通过 ...
- TP5.1:数据库的增删改查操作(基于数据库操作)
1.在app/index/controller文件夹下创建一个文件,名为:Operation 注意:起名一定要避开关键字,例如:mysql,curd等等,如果使用关键字起名,会造成报错! 在Opera ...
- mongoDB 学习笔记纯干货(mongoose、增删改查、聚合、索引、连接、备份与恢复、监控等等)
最后更新时间:2017-07-13 11:10:49 原始文章链接:http://www.lovebxm.com/2017/07/13/mongodb_primer/ MongoDB - 简介 官网: ...
- 详谈easyui datagrid增删改查操作
转自:http://blog.csdn.net/abauch_d/article/details/7734395 前几天我把easyui dadtagrid的增删改查的实现代码贴了出来,发现访问量达到 ...
- JDBC连接数据库及增删改查操作
什么是JDBC?Java语言访问数据库的一种规范,是一套APIJDBC (Java Database Connectivity) API,即Java数据库编程接口,是一组标准的Java语言中的接口和类 ...
- python 全栈开发,Day124(MongoDB初识,增删改查操作,数据类型,$关键字以及$修改器,"$"的奇妙用法,Array Object 的特殊操作,选取跳过排序,客户端操作)
一.MongoDB初识 什么是MongoDB MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介 ...
- AD 域服务简介(三)- Java 对 AD 域用户的增删改查操作
博客地址:http://www.moonxy.com 关于AD 域服务器搭建及其使用,请参阅:AD 域服务简介(一) - 基于 LDAP 的 AD 域服务器搭建及其使用 Java 获取 AD 域用户, ...
- 后盾网lavarel视频项目---lavarel使用模型进行增删改查操作
后盾网lavarel视频项目---lavarel使用模型进行增删改查操作 一.总结 一句话总结: 使用模型操作常用方法 查一条:$model=Tag::find($id); 删一条:Tag::dest ...
- 如何搭建一个WEB服务器项目(二)—— 对数据库表进行基本的增删改查操作
使用HibernateTemplate进行增删改查操作 观前提示:本系列文章有关服务器以及后端程序这些概念,我写的全是自己的理解,并不一定正确,希望不要误人子弟.欢迎各位大佬来评论区提出问题或者是指出 ...
随机推荐
- CocoStudio
不知道从哪里下载的CocoStudio_Full_V1.0.0.1.1185392965.exe 安装后点击"Animation Editor"."UI Editor&q ...
- JSP 介绍
Servlet进行逻辑处理效率高,但是页面响应效率低,不太方便. 问题: 在学习了Servlet之后,使用Servlet进行页面的展现,代码书写过于麻烦. 极大的影响了开发的效率,那么有没有一种方式可 ...
- 服务器的日志一直报Packet for query is too large (7632997 > 4194304). You can change this value on the server by setting the max_allowed_packet' variable.的解决方法
服务器的日志一直报Packet for query is too large (7632997 > 4194304). You can change this value on the serv ...
- 2018.07.17 牛奶模式Milk Patterns(二分+hash)
传送门 一道简单的字符串.这里收集了几种经典做法: SAM,不想写. 后缀数组+二分,不想写 后缀数组+单调队列,不想写 hash+二分,for循哈希,天下无敌!于是妥妥的hash 代码如下: #in ...
- 着重基础之—MySql 不能遗忘的索引操作
着重基础之—MySql 不能遗忘的索引操作 关于MySql索引的基础知识我就不在这里写了,我不太想当信息的搬运工. 技巧分享:Workbench 作为一款专为MySQL设计的ER/数据库建模工具.除了 ...
- [转]一个CMake编译问题的解决过程
问题的提出 公司的一个power-pc平台的产品,有个协议进行了修改,过程中出现了比较奇怪的情况.直接将修改后的动态库下载到设备上(原始设备是有文件系统和其他的依赖文件的,相当于部分更新应用),设备和 ...
- Docker mysql启动自动按顺序导入sql
1.目录结构 -rw-r--r-- root root Jan : Dockerfile -rw-r--r-- root root Jan : initdb.sh drwxr-xr-x root ro ...
- Bluebird-NodeJs的Promise
Promise是异步代码实现控制流的一种方式.这一方式可以让你的代码干净.可读并且健壮. 比如,你用来异步处理文件事件的回调代码: fs.readFile('directory/file-to-rea ...
- 图形与游戏中3D数学基础的说明
1.左手坐标系与右手坐标系没有好坏之分,不同的研究领域和不同的背景下,选择不同的坐标系:传统计算机图形学采用“左手坐标系”,线性代数则倾向于使用右手坐标系 坐标系由坐标轴与坐标原点组成.原点定义坐标系 ...
- hdu 5012 模拟+bfs
http://acm.hdu.edu.cn/showproblem.php?pid=5012 模拟出骰子四种反转方式,bfs,最多不会走超过6步 #include <cstdio> #in ...