简介

mongoose是node.js的一个操作mongodb的模块,比起之前mongodb模块,只需要在开始时连接,不需要手动关闭,十分方便。

连接mongodb

首先你需要安装mongodb。
有了mongodb,你需要引入mongoose模块。

require('mongoose');

然后取连接mongodb

mongoose.connect('mongodb://localhost/myapp');//location是数据库地址,myapp为db名字
//mongoose.connect('mongodb://username:password@host:port/database?options...');

Model

要定义model首先需要定义一个schema.

var schema = new mongoose.Schema({ name: String, age: Number });
//定义model
var personModel = mongoose.model('person', schema);//person为collection名

model适合简单查询,保存,修改和删除。
保存一条新数据:

var saveobj = new persionModel({name:'小明',age:15});
saveobj.save(function(err){
    if(err){
        console.log('save error')
    }else{
        console.log('save successs');
    }
});

查询记录

var query_doc = {age:15};//查询条件
persionModel.find(query_doc,function(err,data){
    if(err){
        console.log('query error');
    }else{
        console.log(data);//此时查询结构为一个数组
    }
});

查询一条记录

var query_doc = {age:15};
personModel.findOne(query_doc,function(err,data){
    if(err){
        console.log('query one error');
    }else{
        console.log(data);//此时为一个结果对象
    }
});

修改一条数据

var update_where = {name:'李四'};//更新条件
var update_data = {age:14};//更新数据
personModel.update(update_where,{$set:update_data},function(err){
    if(err){
        console.log('update error');
    }else{
        console.log('update success');
    }
});

删除一条数据

var del_where = {name:'小明'};//删除条件
personModel.remove(del_where,function(err){
    if(err){
        console.log('delete error');
    }else{
        console.log('delete success');
    }
});

Query

query适合复杂的查询。
首先获取一个query:

var query = personModel.find({});//当不带回调时会返回一个query对象
query
    .skip(10)//跳过十行记录
    .limit(10)//查询十行记录
    .sort({_id:-1})//按id逆序排列
    .where('age').gt(17).lt(66)//age字段大于17小于66
    .exec(function(err,data){
    //回调函数,do some thing
});

简单的mongoose操作mongodb就这么多啦,更多内容可以查看手册。http://www.nodeclass.com/api/mongoose.html

mongoose 的 model,query:增删改查的更多相关文章

  1. node-express项目的搭建并通过mongoose操作MongoDB实现增删改查分页排序(四)

    最近写了一个用node来操作MongoDB完成增.删.改.查.排序.分页功能的示例,并且已经放在了服务器上地址:http://39.105.32.180:3333. Mongoose是在node.js ...

  2. 夺命雷公狗---Thinkphp----7之栏目配合Model的增删改查

    我们首先来写一个查: public function lists(){ $type = M('Type')->select(); $this -> assign('type',$type) ...

  3. Node使用Mongoose操作MongoDB数据库——增删改查的实现

    当初刚出社会时就规划了下自己的职业生涯:先成为一名优秀的前端工程师,再成为一名全栈工程师(精通前端开发.后台开发和客户端开发),最后成为一名优秀的系统架构师.转眼间已经工作快三年,是时候迈出关键性的一 ...

  4. IndexedDB 增删改查 简单的库

    <!DOCTYPE html> <html> <head> <title></title> <script src="Ind ...

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

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

  6. mongoDB (mongoose、增删改查、聚合、索引、连接、备份与恢复、监控等等)

    MongoDB - 简介 官网:https://www.mongodb.com/ MongoDB 是一个基于分布式文件存储的数据库,由 C++ 语言编写,旨在为 WEB 应用提供可扩展的高性能数据存储 ...

  7. 手把手教你基于koa2,mongoose实现增删改查

    初始化项目 npm init -y 先安装一波乱七八糟的依赖插件(需要具备一定的koa2知识,至于mongoDB自行百度安装教程),模板引擎我使用的是art-template(据说是性能最好的,而且是 ...

  8. DjangoMTV模型之model层——ORM操作数据库(基本增删改查)

    Django的数据库相关操作 对象关系映射(英语:(Object Relational Mapping,简称ORM),是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换.从效果上说 ...

  9. 使用Mongoose类库实现简单的增删改查

    使用Mongoose类库实现简单的增删改查 Mongoose是在nodejs环境中对MongoDB数据库操作的封装,一种对象模型工具,可以将数据库中的数据转换为javascript对象供我们使用. M ...

  10. VUE2.0增删改查附编辑添加model(弹框)组件共用

    Vue实战篇(增删改查附编辑添加model(弹框)组件共用) 前言 最近一直在学习Vue,发现一份crud不错的源码 预览链接 https://taylorchen709.github.io/vue- ...

随机推荐

  1. Xshell远程连接工具

    下载地址:http://rj.baidu.com/soft/detail/15201.html?ald Xshell 是一个强大的安全终端模拟软件,它支持SSH1, SSH2, 以及Microsoft ...

  2. 【转】一个新的UIButtonMessage 给NGUI,使用委托,自动选择Receiver提供的方法

    http://blog.csdn.net/chiuan/article/details/9290651?utm_source=tuicool&utm_medium=referral 来分享一个 ...

  3. 包管理工具Carthage使用

    iOS项目中第三方开源库的工具有Cocoapods和Carthage,swift官方出了一个包管理工具SPM(Swift Package Manager). 首先,大体讲一下Cocoapods和Car ...

  4. [原创]如何在Parcelable中使用泛型

    [原创]如何在Parcelable中使用泛型 实体类在实现Parcelable接口时,除了要实现它的几个方法之外,还另外要定义一个静态常量CREATOR,如下例所示: public static cl ...

  5. LeetCode Reverse String

    原题链接在这里:https://leetcode.com/problems/reverse-string/ 题目: Write a function that takes a string as in ...

  6. vim - mark

    Using markshttp://vim.wikia.com/wiki/Using_marks1. There is no visible indication of where marks are ...

  7. 扩展映射 Diffusion maps

    Diffusion maps接触到扩展映射,高维数据降维的相关东西. 扩展映射是一种非线性方法.

  8. oracle指令

    删除用户和用户下所有的表: drop user user_name cascade; 导入数据库: cd /home/oracle/app/admin/orcl/dpdump impdp   dire ...

  9. 如何发布一个Mac应用并使其成为全球付费榜第一

    Readdle公司如何发布第一个 Mac App,并使之成为Mac App Store 全球付费排名第一的 Easy注:自从发布了<程序员如何优雅的挣零花钱?>后,就不断有同学询问怎么做A ...

  10. Liunx下的系统负荷

                uptime命令回显中的load average所表示的意思和w命令相似,都是表示过去的1分钟.5分钟和15分钟内进程队列中的平均进程数量. 这里需要注意的是load aver ...