Mongoose 参考手册
2019独角兽企业重金招聘Python工程师标准>>>
Mongoose 参考手册
Mongoose 是什么?
一般我们不直接用MongoDB的函数来操作MongoDB数据库 Mongose就是一套操作MongoDB数据库的接口.
Schema
一种以文件形式存储的数据库模型骨架,无法直接通往数据库端,也就是说它不具备对数据库的操作能力.可以说是数据属性模型(传统意义的表结构),又或着是“集合”的模型骨架
/* 定义一个 Schema */
var mongoose = require("mongoose");var TestSchema = new mongoose.Schema({name : { type:String },//属性name,类型为Stringage : { type:Number, default:0 },//属性age,类型为Number,默认为0time : { type:Date, default:Date.now },email: { type:String,default:''}
});
上面这个 TestSchema包含4个属性 [name, age, time, email]
Model
由Schema构造生成的模型,除了Schema定义的数据库骨架以外,还具有数据库操作的行为,类似于管理数据库属性、行为的类
var db = mongoose.connect("mongodb://127.0.0.1:27017/test");// 创建Model
var TestModel = db.model("test1", TestSchema);
test1 数据库中的集合名称, 不存在会创建.
Entity
由Model创建的实体,使用save方法保存数据,Model和Entity都有能影响数据库的操作,但Model比Entity更具操作性
var TestEntity = new TestModel({name : "Lenka",age : 36,email: "lenka@qq.com"
});
console.log(TestEntity.name); // Lenka
console.log(TestEntity.age); // 36
游标
MongoDB 使用游标返回find的执行结果.客户端对游标的实现通常能够对最终结果进行有效的控制。可以限制结果的数量,略过部分结果,根据任意键按任意顺序的组合对结果进行各种排序,或者是执行其他一些强的操作。
ObjectId
存储在mongodb集合中的每个文档(document)都有一个默认的主键_id,这个主键名称是固定的,它可以是mongodb支持的任何数据类型,默认是ObjectId。
ObjectId是一个12字节的 BSON 类型字符串。按照字节顺序,依次代表: 4字节:UNIX时间戳 3字节:表示运行MongoDB的机器 2字节:表示生成此_id的进程 3字节:由一个随机数开始的计数器生成的值
Node.js 中
package.json 中加入"mongoose": “*” 字段 npm install 安装依赖.
var mongoose = require("mongoose");
var db = mongoose.connect("mongodb://localhost:27017/test");
然后引用
API
var mongoose = require("mongoose");
var db = mongoose.connect("mongodb://localhost:27017/test");
db - 数据库操作
1.挂接数据库连接事件,参数1: 也可以是error.
db.connection.on(‘open’, callback);
Schema - 表结构
1.构造函数
new mongoose.Schema( { name:{type:String}, age:{type:Number, default:10} } )
2.添加属性
Schema.add( { name: ‘String’, email: ‘String’, age: ‘Number’ } )
3.有时候Schema不仅要为后面的Model和Entity提供公共的属性,还要提供公共的方法
Schema.method( ‘say’, function(){console.log(‘hello’);} ) //这样Model和Entity的实例就能使用这个方法了
4.添加静态方法
Schema.static( ‘say’, function(){console.log(‘hello’);} ) //静态方法,只限于在Model层就能使用
5.追加方法
Schema.methods.say = function(){console.log(‘hello’);}; //静态方法,只限于在Model层就能使用
model - 文档操作
1.构造函数, 参数1:集合名称, 参数2:Schema实例
db.model(“test1”, TestSchema );
2.查询, 参数1忽略,或为空对象则返回所有集合文档
model.find({}, callback);
model.find({},field,callback); 过滤查询,参数2: {‘name’:1, ‘age’:0} 查询文档的返回结果包含name , 不包含age.(_id默认是1)
model.find({},null,{limit:20}); 过滤查询,参数3: 游标操作 limit限制返回结果数量为20个,如不足20个则返回所有.
model.findOne({}, callback); 查询找到的第一个文档
model.findById(‘obj._id’, callback); 查询找到的第一个文档,同上. 但是只接受 __id 的值查询
3.创建, 在集合中创建一个文档
Model.create(文档数据, callback))
4.更新,参数1:查询条件, 参数2:更新对象,可以使用MondoDB的更新修改器
Model.update(conditions, update, function(error)
5.删除, 参数1:查询条件
Model.remove(conditions,callback);
Entity - 文档操作
1.构造函数, 其实就是model的实例
new TestModel( { name:‘xueyou’, age:21 } );
2.创建, 在集合中创建一个文档.
Entity.save(callback);
修改器和更新器
更新修改器:
‘$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”:{"$skice" : 10} } ); 查询 匹配array数组的前10个元素
Model.find({“array”:{"$skice" : [5,10] } } ); 查询 匹配array数组的第5个到第10个元素
where
用它可以执行任意javacript语句作为查询的一部分,如果回调函数返回 true 文档就作为结果的一部分返回
find( {"$where" : function(){for( var x in this ){//这个函数中的 this 就是文档}if(this.x !== null && this.y !== null){return this.x + this.y === 10 ? true : false;}else{return true;}} } )
简化版本
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降序
转载于:https://my.oschina.net/fadoudou/blog/1550293
Mongoose 参考手册相关推荐
- html iso标准文档,HTML ISO-8859-1 参考手册
# HTML ISO-8859-1 参考手册 HTML 4.01 支持 ISO 8859-1 (Latin-1) 字符集. ISO-8859-1 的较低部分(从 1 到 127 之间的代码)是最初的 ...
- 陈长沙:学习者参考手册
学习者参考手册 组队学习的核心是"和一群有意思的人在一起学感兴趣的知识的过程,这个过程充满了人与人之间的交流互动,是融入社交属性和学习属性的过程".作为参与组队学习活动的学习者,一 ...
- 组队学习:学习者参考手册
学习者参考手册 作为希望参与组队学习活动的学习者,一定想了解有关本次活动的各种环节.我就通过这份手册来给大家介绍一下. 本手册一共分为四个部分,分别是活动角色划分,活动流程介绍.打卡环节介绍.角色职责 ...
- GDB 命令参考手册
GDB 命令参考手册 ...
- CSS选择器和参考手册
CSS的基本语法 选择器:通过选择器可以选中页面中的指定元素.声明块:通过声明块来指定元素设置样式.声明块由一个一个的声明组成声明是由一个名值对结构:一个样式名对应一个样式值,名和值之间以:连接,以; ...
- 230套java web开发PDF书籍和CHM参考手册资料大全 免费下载
230套java web开发PDF书籍和CHM参考手册资料大全 免费下载 下载地址:http://yun.baidu.com/s/169jYH 文章来源:HTML5星空http://www.html5 ...
- 如何制作在线参考手册
看到很多网站的在线的手册,自己很是好奇,准备自己也搞一个在线手册,下面是制作过程 制作在线参考手册 步骤: 要有chm版本的手册 转换chm为html,推荐工具:CHM Encoder绿色版 制作手册 ...
- Python 参考手册
声明:转载自 http://blog.csdn.net/jerry_1126/article/details/41240149#comments 感谢作者的辛勤总结! 由于作者的python版本是2. ...
- html dom对象简写,js参考手册-html dom对象
Browser 对象参考手册 对象 描述 Window JavaScript 层级中的顶层对象,表示浏览器窗口. Navigator 包含客户端浏览器的信息. Screen 包含客户 ...
- WinCvs 操作参考手册
为什么80%的码农都做不了架构师?>>> WinCvs 操作参考手册 本参考手册使用WinCvs 1.3.24(Build 1)进行实例说明. 1.设置工作目录 在目录&quo ...
最新文章
- 不止于刷榜,三大CV赛事夺冠算法技术的“研”与“用”
- 记忆优化搜索(简单题)(洛谷P3183 [HAOI2016]食物链 )( P5635 【CSGRound1】天下第一 )
- 联想ThinkPad E450装系统后开机一直停留在BootMenu上,无法选择硬盘进入
- Linux系统用户环境变量大全,linux系统和用户环境变量的配置文件
- leetcode309. 最佳买卖股票时机含冷冻期
- odoo连接外部数据库
- 对交换机VLAN及各种端口类型的理解
- 无处不在的container_of
- 不是技术牛人,如何拿到国内IT巨头的Offer(转载)
- 关于stm32的正交解码
- 易语言版{大智慧/分析家/飞狐交易师}DLL插件接口开发模块(beta),自定义股票软件公式扩展函数...
- 水滴的“创益矩阵”:“万物”皆可连接公益
- 谷歌大神 Jeff Dean 的那些“惊人真相”
- js禁止输入框输入特殊符号或emoji表情
- 汉王速录笔linux驱动下载,汉王速录笔v586s驱动
- 【UCOSii源码解析】任务间通讯与同步
- 算法小白鼠毒药c语言,EM笔试题收藏 .doc
- Scratch绘制蜘蛛网1
- python+pyhyper实现识别图片中的车牌号
- 免安装Oracle客户端和PL/SQL
热门文章
- Netty的并发编程实践2:volatile的正确使用
- 安全云服务的定义和特征
- 详解tensorflow数据读取-tf.train.string_input_producer和tf.train.start_queue_runners
- android slidingmenu 兼容低版本,Android SlidingMenu的使用详解
- linux 内核恐慌,linux – CentOS 6.5 mdadm Raid 1 – raid数据检查期间的内核恐慌
- SQL Server-【知识与实战VII】存储过程(上)
- Android 饼状图(MPAndroidChart框架)
- 调试wifi简单记录
- 微云笔记控制脚本实例:远程控制脚本开关
- 最大数组全局还是局部的问题