博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mongoose 的那些基础操作
阅读量:6295 次
发布时间:2019-06-22

本文共 6198 字,大约阅读时间需要 20 分钟。

mongoose 连接mongodb

var mongoose = require('mongoose');var db       = mongoose.createConnection('mongodb://127.0.0.1:27017/NodeJS'); // 链接错误db.on('error', function(error) {    console.log(error);});

Schema 结构

var mongooseSchema = new mongoose.Schema({    username : {type : String, default : '匿名用户'},    title    : {type : String},    content  : {type : String},    time     : {type : Date, default: Date.now},    age      : {type : Number}});

Schema的types

var schema = new Schema({  name:    String,  binary:  Buffer,  living:  Boolean,  updated: { type: Date, default: Date.now },  age:     { type: Number, min: 18, max: 65 },  mixed:   Schema.Types.Mixed,  _someId: Schema.Types.ObjectId,  array:      [],  ofString:   [String],  ofNumber:   [Number],  ofDates:    [Date],  ofBuffer:   [Buffer],  ofBoolean:  [Boolean],  ofMixed:    [Schema.Types.Mixed],  ofObjectId: [Schema.Types.ObjectId],  nested: {    stuff: { type: String, lowercase: true, trim: true }  }})

添加 mongoose 实例方法,实例上使用的方法

mongooseSchema.methods.findbyusername = function(username, callback) {    return this.model('mongoose').find({username: username}, callback);}

添加 mongoose 静态方法,静态方法在Model层就能使用

mongooseSchema.statics.findbytitle = function(title, callback) {    return this.model('mongoose').find({title: title}, callback);}

model

var mongooseModel = db.model('mongoose', mongooseSchema);

增加记录 基于 entity 操作

var doc = {username : 'emtity_demo_username', title : 'emtity_demo_title', content : 'emtity_demo_content'};var mongooseEntity = new mongooseModel(doc);mongooseEntity.save(function(error) {    if(error) {        console.log(error);    } else {        console.log('saved OK!');    }    // 关闭数据库链接    db.close();});

增加记录 基于model操作

var doc = {username : 'model_demo_username', title : 'model_demo_title', content : 'model_demo_content'};mongooseModel.create(doc, function(error){    if(error) {        console.log(error);    } else {        console.log('save ok');    }    // 关闭数据库链接    db.close();});

修改记录

mongooseModel.update(conditions, update, options, callback);var conditions = {username : 'model_demo_username'};var update     = {$set : {age : 27, title : 'model_demo_title_update'}};var options    = {upsert : true};mongooseModel.update(conditions, update, options, function(error){    if(error) {        console.log(error);    } else {        console.log('update ok!');    }    //关闭数据库链接    db.close();});
  • update()返回数据处理条数
  • findOneAndUpdate()返回处理后的数据
  • 简单来说,你需要获取数据就用findOneAndUpdate(),只需要修改数据而不关注修改后数据那就用update()

查询

基于实例方法的查询

var mongooseEntity = new mongooseModel({});mongooseEntity.findbyusername('model_demo_username', function(error, result){    if(error) {        console.log(error);    } else {        console.log(result);    }    //关闭数据库链接    db.close();});

基于静态方法的查询

mongooseModel.findbytitle('emtity_demo_title', function(error, result){    if(error) {        console.log(error);    } else {        console.log(result);    }    //关闭数据库链接    db.close();});

mongoose find

var criteria = {title : 'emtity_demo_title'}; // 查询条件var fields   = {title : 1, content : 1, time : 1}; // 待返回的字段var options  = {};mongooseModel.find(criteria, fields, options, function(error, result){    if(error) {        console.log(error);    } else {        console.log(result);    }    //关闭数据库链接    db.close();});

删除记录

var conditions = {username: 'emtity_demo_username'};mongooseModel.remove(conditions, function(error){    if(error) {        console.log(error);    } else {        console.log('delete ok!');    }    //关闭数据库链接    db.close();});

修改器和更新器

更新修改器:

  • $inc 增减修改器,只对数字有效.下面的实例: 找到 age=22的文档,修改文档的age值自增1
Model.update({‘age’:22}, {’$inc’:{‘age’:1} }  ); 执行后: age=23
  • $set 指定一个键的值,这个键不存在就创建它.可以是任何MondoDB支持的类型.
Model.update({‘age’:22}, {’$set’:{‘age’:‘haha’} }  ); 执行后: age=‘haha’
  • $unset 同上取反,删除一个键
Model.update({‘age’:22}, {’$unset’:{‘age’:‘haha’} }  ); 执行后: age键不存在

数组修改器:

  • $push 给一个键push一个数组成员,键不存在会创建
Model.update({‘age’:22}, {’$push’:{‘array’:10} } ); 执行后: 增加一个 array 键,类型为数组, 有一个成员 10
  • $addToSet 向数组中添加一个元素,如果存在就不添加
Model.update({‘age’:22}, {’$addToSet’:{‘array’:10} } ); 执行后: array中有10所以不会添加
  • $each 遍历数组, 和 $push 修改器配合可以插入多个值
Model.update({‘age’:22}, {’$push’:{‘array’:{’$each’: [1,2,3,4,5]}} } ); 执行后: array : [10,1,2,3,4,5]
  • $pop 向数组中尾部删除一个元素
Model.update({‘age’:22}, {’$pop’:{‘array’:1} } ); 执行后: array : [10,1,2,3,4] tips: 将1改成-1可以删除数组首部元素
  • $pull 向数组中删除指定元素
Model.update({‘age’:22}, {’$pull’:{‘array’:10} } ); 执行后: array : [1,2,3,4] 匹配到array中的10后将其删除

条件查询:

  • $lt 小于
  • $lte 小于等于
  • $gt 大于
  • $gte 大于等于
  • $ne 不等于
Model.find({“age”:{ “$get”:18 , “$lte”:30 } } ); 查询 age 大于等于18并小于等于30的文档

或查询 OR:

  • $in 一个键对应多个值
  • $nin 同上取反, 一个键不对应指定值
  • $or 多个条件匹配, 可以嵌套 $in 使用
  • $not 同上取反, 查询与特定模式不匹配的文档
Model.find({“age”:{ “$in”:[20,21,22.‘haha’]} } ); 查询 age等于20或21或21或’haha’的文档
Model.find({"$or" :  [ {‘age’:18} , {‘name’:‘xueyou’} ] }); 查询 age等于18 或 name等于’xueyou’ 的文档

类型查询:

null 能匹配自身和不存在的值, 想要匹配键的值 为null, 就要通过 $exists条件判定键值已经存在 $exists (表示是否存在的意思)

Model.find(“age” :  { “$in” : [null] , “exists” : true  } ); 查询 age值为null的文档
Model.find({name:{$exists:true}},function(error,docs){//查询所有存在name属性的文档});Model.find({telephone:{$exists:false}},function(error,docs){//查询所有不存在telephone属性的文档});

正则表达式:

MongoDb 使用 Prel兼容的正则表达式库来匹配正则表达式

find( {“name” : /joe/i } ) 查询name为 joe 的文档, 并忽略大小写find( {“name” : /joe?/i } ) 查询匹配各种大小写组合

查询数组:

Model.find({“array”:10} ); // 查询 array(数组类型)键中有10的文档, array : [1,2,3,4,5,10] 会匹配到
Model.find({“array[5]”:10} ); 查询 array(数组类型)键中下标5对应的值是10, array : [1,2,3,4,5,10] 会匹配到
  • $all 匹配数组中多个元素
Model.find({“array”:[5,10]} ); 查询 匹配array数组中 既有5又有10的文档
  • $size 匹配数组长度
Model.find({“array”:{"$size" : 3} } ); 查询 匹配array数组长度为3 的文档
  • $slice 查询子集合返回
Model.find({“array”:{"$slice" : 10} } ); 查询 匹配array数组的前10个元素Model.find({“array”:{"$slice" : [5,10] } } ); 查询 匹配array数组的第5个到第10个元素

where

用它可以执行任意javacript语句作为查询的一部分,如果回调函数返回 true 文档就作为结果的一部分返回

find({"$where":function(){for(var x in this){//这个函数中的 this 就是文档}if(this.x !==null&&this.y !==null){returnthis.x +this.y ===10?true:false;}else{returntrue;}}})

简化版本

find( {"$where" :  "this.x + this.y === 10" } )find( {"$where" : " function(){ return this.x + this.y ===10; } " } )

游标:

  • limit(3) 限制返回结果的数量,
  • skip(3) 跳过前3个文档,返回其余的
  • sort( {“username”:1 , “age”:-1 } )
排序 键对应文档的键名, 值代表排序方向, 1 升序, -1降序

保存数组json

删除多条数据

转载地址:http://ipvta.baihongyu.com/

你可能感兴趣的文章
中间件
查看>>
Android SharedPreferences
查看>>
css面试题
查看>>
Vue组建通信
查看>>
用CSS画一个带阴影的三角形
查看>>
前端Vue:函数式组件
查看>>
程鑫峰:1.26特朗.普力挺美元力挽狂澜,伦敦金行情分析
查看>>
safari下video标签无法播放视频的问题
查看>>
01 iOS中UISearchBar 如何更改背景颜色,如何去掉两条黑线
查看>>
对象的继承及对象相关内容探究
查看>>
Spring: IOC容器的实现
查看>>
Serverless五大优势,成本和规模不是最重要的,这点才是
查看>>
Nginx 极简入门教程!
查看>>
iOS BLE 开发小记[4] 如何实现 CoreBluetooth 后台运行模式
查看>>
Item 23 不要在代码中使用新的原生态类型(raw type)
查看>>
为网页添加留言功能
查看>>
JavaScript—数组(17)
查看>>
Android 密钥保护和 C/S 网络传输安全理论指南
查看>>
以太坊ERC20代币合约优化版
查看>>
Why I Began
查看>>