NodeJs Mongoose 常用 CRUD 起步

安装 Mongoose

npm install mongoose --save  

导入中间件

var express = require('express');  
var router = express.Router();  
var mongoose = require('mongoose');  

链接数据库

var db = mongoose.createConnection('localhost', 'lyTest');  

定义 Schema, 也就是传统意义的表结构

var personSchema = new mongoose.Schema({  
    _name: String, //定义一个属性 name, 类型为 String
    _phone: Number
});

定义 Model

var personModel = db.model('luoyanArr', personSchema);  

常用操作 CRUD

测试数据

var obj = {  
    _name: 'luoyan',
    _phone: 111
}

添加数据

// 方法 1
var personEntity = new personModel(obj);

personEntity.save(function (err) {  
    if (err) {
      console.log('insert failed');
    } else {
      console.log('insert success');
    }
});

// 方法 2
personModel.create(obj, function (err) {  
    if (err) {
      console.log('insert failed');
    } else {
      console.log('insert success');
    }
});

注意: 在添加数据的时候, 如果不指定 id 属性, id 会默认为一个字符串对象.

区别: Entity 是 model 的对象, 用它来添加数据的时候会把隐藏属性一起存入数据库, 有几率报错 model 只能添加纯净的 json 对象, 不能添加它创建的实体.

修改操作

// 方法 1
personModel.update({_phone: 222}, {$set: {_name: '把222的都改了'}}, { multi: true}, function(err){  
    if (err) { // 错误
       console.log('update failed');
    } else { // 正确
       console.log('update success');
    }
});

// 方法 2
var id = "56fc1bbe7c2bce52c38fc5f8";  
personModel.findById(id, function(err, person){  
     if (err) {
        console.log('update failed');
     } else {
        person._name = 'from_id';
        person.save(function(err){ ... });
        console.log('update success');
     }
});

注意: 如果更新的数据比较少的话, 用方法一很方便的, 其中的 { multi: true } 表示同时更新所有数据, { multi: false } 或者省略则只跟新一条

查询数据

直接查询

personModel.findOne({'_phone': 111}, function (err, person) {  
    if (err) {
       console.log('select failed');
    } else {
       console.log( person );
    }
});

查询一条

var query = personModel.findOne({'_phone': 111});  
query.select();  
query.exec(function(err, person){  
     if (err) {
        console.log('select failed');
     } else {
        console.log(person);
     }
});

查询多条

var query = personModel.find({'_phone': 222});  
query.select();  
query.exec(function(err, person){  
     if (err) {
        console.log('select failed');
     } else {
        console.log(person);
     }
});

链式查询

personModel  
     .where('_phone')
     .where('_name').equals('aaa')
     .limit(2)
     .select()
     .exec(function (err, person) {
          if (err) {
              console.log('select failed');
          } else {
              console.log(person);
          }
     });

另外附详细链式查询表

personModel //model 对象  
     .find({ occupation: /host/ }) // 条件
     .where('name.last').equals('Ghost') //字段 = 值
     .where('age').gt(17).lt(66) // 范围
     .where('likes').in(['vaporizing', 'talking']) // 范围
     .limit(10) // 查几条
     .skip(20) // 跳过几条
     .asc('age') // 排序
     .sort('-occupation')
     .slaveOk()
     .hint({ age: 1, name: 1 })
     .select('name occupation') // 执行查询 () 中的值可以省略, 只是别名
     .exec(callback); // 回调函数, 处理查询结果

删除操作

var personEntity = new personModel();  
personModel.remove({_id:"56fc281ab64732d8c33b4db7"}, function (err) {  
     if (err) {
       console.log('delete failed');
     } else {
       console.log('detete success');
     }
});

注意: 删除条件一定是唯一的, 不然就清库了.

罗彦笔记连接

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 安装 Mongoose 导入中间件 链接数据库 定义 Schema, 也就是传统意义的表结构 定义 Model 常...
    云龙789阅读 267评论 0 0
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,975评论 25 708
  • Mongodb 配置选项 通常在mongod.conf中 配置文件 设置了配置文件后启动时以自定义的配置文件启动:...
    AkaTBS阅读 1,090评论 0 6
  • 每次出行的目的地,都是自己向往已久的;每次出行前的准备,也在一次又一次的历练中得到成长;每次出行回来,还会一直流连...
    霍虹阅读 787评论 0 2
  • 有些忍耐,无来无去,无有无印,透着无尽的慈悲…… 有些忍耐,带着含蓄,藏着隐逸,保有静默,它使时光平和淡远,它让岁...
    燕儿_7bb6阅读 464评论 0 2