无论是基于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 的增删改查操作的更多相关文章

  1. TP5.1:数据库的增删改查操作(基于面向对象操作)

    我们现实中对数据库的增删改查操作,都是使用模型类进行操作的(表名::),也就是面向对象操作,只有底层的代码用的是数据库操作(Db::table('表名')) 下面我将贴出模型类进行的增删改查操作,通过 ...

  2. TP5.1:数据库的增删改查操作(基于数据库操作)

    1.在app/index/controller文件夹下创建一个文件,名为:Operation 注意:起名一定要避开关键字,例如:mysql,curd等等,如果使用关键字起名,会造成报错! 在Opera ...

  3. mongoDB 学习笔记纯干货(mongoose、增删改查、聚合、索引、连接、备份与恢复、监控等等)

    最后更新时间:2017-07-13 11:10:49 原始文章链接:http://www.lovebxm.com/2017/07/13/mongodb_primer/ MongoDB - 简介 官网: ...

  4. 详谈easyui datagrid增删改查操作

    转自:http://blog.csdn.net/abauch_d/article/details/7734395 前几天我把easyui dadtagrid的增删改查的实现代码贴了出来,发现访问量达到 ...

  5. JDBC连接数据库及增删改查操作

    什么是JDBC?Java语言访问数据库的一种规范,是一套APIJDBC (Java Database Connectivity) API,即Java数据库编程接口,是一组标准的Java语言中的接口和类 ...

  6. python 全栈开发,Day124(MongoDB初识,增删改查操作,数据类型,$关键字以及$修改器,"$"的奇妙用法,Array Object 的特殊操作,选取跳过排序,客户端操作)

    一.MongoDB初识 什么是MongoDB MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介 ...

  7. AD 域服务简介(三)- Java 对 AD 域用户的增删改查操作

    博客地址:http://www.moonxy.com 关于AD 域服务器搭建及其使用,请参阅:AD 域服务简介(一) - 基于 LDAP 的 AD 域服务器搭建及其使用 Java 获取 AD 域用户, ...

  8. 后盾网lavarel视频项目---lavarel使用模型进行增删改查操作

    后盾网lavarel视频项目---lavarel使用模型进行增删改查操作 一.总结 一句话总结: 使用模型操作常用方法 查一条:$model=Tag::find($id); 删一条:Tag::dest ...

  9. 如何搭建一个WEB服务器项目(二)—— 对数据库表进行基本的增删改查操作

    使用HibernateTemplate进行增删改查操作 观前提示:本系列文章有关服务器以及后端程序这些概念,我写的全是自己的理解,并不一定正确,希望不要误人子弟.欢迎各位大佬来评论区提出问题或者是指出 ...

随机推荐

  1. vue-router2.0 初学--动态赋值

    A:router路由配置 1 export default new Router({ 2 routes: [ 3 { 4 path: '/home', 5 name: 'Home', 6 compon ...

  2. 我所理解的 Laravel 请求 生命周期

    转载自:https://laravel-china.org/topics/3343/my-understanding-of-the-laravel-request-life-cycle 当你使用一个工 ...

  3. Jmeter从一个Reply Message中获取N个参数的值,然后根据这个参数对后面的操作循环N次(ForEach Controller的用法)

    假设Reply Message是这样的: <root><result code="0" msg="success" /><m k= ...

  4. Mockplus是如何节省你的原型时间的?

    还在用老牌原型工具一点点绘制产品原型吗?还在为实现一个满意的交互而绞尽脑汁吗?还在为无法和用户高效沟通而发愁吗?朋友,现在是快速原型的时代了.时间不等人,当你精雕细琢完成产品启动页的时候,别人的原型已 ...

  5. bat 调用exe

    @set errorlevel=>nul :reInput @echo 请输入批次号: @set/p 批次号= >nul @set 批次号|findstr "\\<%sea ...

  6. android textview settext卡顿深层次原因

    最近在公司项目里面发现listview里面的textview在调用settext函数的时候非常耗时,当时都有点不敢相信,这是因为如果你把textview设置成wrap_content,则每次调用set ...

  7. 简单的socket编程

    1.socket 服务器搭建 实例化socket服务器,循环获取请求 package com.orange.util; import java.io.IOException; import java. ...

  8. tty linux 打开和设置范例

    http://bbs.csdn.net/topics/340184140 /************************************************************** ...

  9. Maximum profit of stocks

    https://github.com/Premiumlab/Python-for-Algorithms--Data-Structures--and-Interviews/blob/master/Moc ...

  10. Linux下一个简单sniffer的实现

    Sniffer(嗅探器)是一种基于被动侦听原理的网络分析方式.将网络接口设置在监听模式,便可以将网上传输的源源不断的信息截获.对于网络监听的基本原理我们不在赘述,我们也不开启网卡的混杂模式,因为现在的 ...