[关闭]
@Bios 2018-12-10T08:47:08.000000Z 字数 4875 阅读 871

mongoose mongodb

mongodb mongoose


mongoose 链接

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

Schema 结构

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

添加 mongoose 实例方法

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

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

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

model

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

增加记录 基于 entity 操作

  1. var doc = {username : 'emtity_demo_username', title : 'emtity_demo_title', content : 'emtity_demo_content'};
  2. var mongooseEntity = new mongooseModel(doc);
  3. mongooseEntity.save(function(error) {
  4. if(error) {
  5. console.log(error);
  6. } else {
  7. console.log('saved OK!');
  8. }
  9. // 关闭数据库链接
  10. db.close();
  11. });

增加记录 基于model操作

  1. var doc = {username : 'model_demo_username', title : 'model_demo_title', content : 'model_demo_content'};
  2. mongooseModel.create(doc, function(error){
  3. if(error) {
  4. console.log(error);
  5. } else {
  6. console.log('save ok');
  7. }
  8. // 关闭数据库链接
  9. db.close();
  10. });

修改记录

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

查询

基于实例方法的查询

  1. var mongooseEntity = new mongooseModel({});
  2. mongooseEntity.findbyusername('model_demo_username', function(error, result){
  3. if(error) {
  4. console.log(error);
  5. } else {
  6. console.log(result);
  7. }
  8. //关闭数据库链接
  9. db.close();
  10. });

基于静态方法的查询

  1. mongooseModel.findbytitle('emtity_demo_title', function(error, result){
  2. if(error) {
  3. console.log(error);
  4. } else {
  5. console.log(result);
  6. }
  7. //关闭数据库链接
  8. db.close();
  9. });

mongoose find

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

删除记录

  1. var conditions = {username: 'emtity_demo_username'};
  2. mongooseModel.remove(conditions, function(error){
  3. if(error) {
  4. console.log(error);
  5. } else {
  6. console.log('delete ok!');
  7. }
  8. //关闭数据库链接
  9. db.close();
  10. });

修改器和更新器

更新修改器:

  1. Model.update({‘age’:22}, {’$inc’:{‘age’:1} } ); 执行后: age=23
  1. Model.update({‘age’:22}, {’$set’:{‘age’:‘haha’} } ); 执行后: age=‘haha
  1. Model.update({‘age’:22}, {’$unset’:{‘age’:‘haha’} } ); 执行后: age键不存在

数组修改器:

  1. Model.update({‘age’:22}, {’$push’:{‘array’:10} } ); 执行后: 增加一个 array 键,类型为数组, 有一个成员 10
  1. Model.update({‘age’:22}, {’$addToSet’:{‘array’:10} } ); 执行后: array中有10所以不会添加
  1. Model.update({‘age’:22}, {’$push’:{‘array’:{’$each’: [1,2,3,4,5]}} } ); 执行后: array : [10,1,2,3,4,5]
  1. Model.update({‘age’:22}, {’$pop’:{‘array’:1} } ); 执行后: array : [10,1,2,3,4] tips: 1改成-1可以删除数组首部元素
  1. Model.update({‘age’:22}, {’$pull’:{‘array’:10} } ); 执行后: array : [1,2,3,4] 匹配到array中的10后将其删除

条件查询:

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

或查询 OR:
- $in 一个键对应多个值
- $nin 同上取反, 一个键不对应指定值
- $or 多个条件匹配, 可以嵌套 $in 使用
- $not 同上取反, 查询与特定模式不匹配的文档

  1. Model.find({“age”:{ $in”:[20,21,22.haha’]} } ); 查询 age等于202121或’haha’的文档
  1. Model.find({"$or" : [ {‘age’:18} , {‘name’:‘xueyou’} ] }); 查询 age等于18 name等于’xueyou 的文档

类型查询:

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

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

正则表达式:

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

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

查询数组:

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

where

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

  1. 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;}}})

简化版本

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

游标:

排序 键对应文档的键名, 值代表排序方向, 1 升序, -1降序

保存数组json

删除多条数据

Mongoose增删改查

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注