Mongodb 数据类型及Mongoose常用CURD
前言
看完了Node.js实战,其中在数据存储部分提到了Redis、Mongodb,我自己也根据书中的介绍写了几个简单的demo,在demo的过程首先遇到的问题就是数据类型和常见的CURD写法。 mongodb的常见操作有两种方式,一个是直接使用API,也就相当于你在SQL Server客户端中使用T-SQL编写SQL语句来操作数据一样,其次就是在程序中使用mongoose驱动来操作数据,相当于我们在程序里用ADO.NET或EF来操作数据,如果你已经写了几个调用API的demo,那么我建议再回过头来看看mongoose的API,多看API,并且记住常见的几个方法比如where,skip,sort等
按照以往我们编写Web方式,我们会关注数据从客户端(Views)如果到Controller层, 然后把数据如何从Controller层传递到Dao层以及这两个层面传递数据时的一些技巧,那么在Node里这种思维也是适用的。
Mongodb数据类型
1、null。{"x":null}。
2、Boolean。{"x":true} 、{"x":false}。
3、数据类型。在Mongodb Shell中默认使用64位浮点型数据,如{"x":2.32}、{"x":2},如果要使用整数类型则用{"x":NumberInt(2)}、{"x":NumberLong(2)}。
4、字符串。Mongodb中字符串采用UTF-8编码方式,{"x":"hello world"}。
5、日期类型。{"x":new Date()}。
6、正则表达式。 Mongodb中可使用和javascript相同的正则表达式 {"x":/itbilu/i}。
7、数据。Mongodb中数组的使用和javascript相同{"x":["hello","world"]}。
8、内嵌文档。{"x":{"y":"Hello"}}。
9、Id和ObjectId()。Mongodb每个文档都会包含一个_id,如果你不指定时Mongodb会自动生成一个ObjectId对象。
10、代码。{"x":function aa(){}}。
11、二进制。
常见CURD
var mongoose=require('mongoose');
var Schema=mongoose.Schema; //1、连接字符串
mongoose.connect('mongodb://localhost/test'); //2、定义你的数据模型(也就是我们在关系数据库中定义的Table)
var TodoSchema=new Schema({
title:String,
finished:{type:Boolean,default:false},
post_date:{type:Date,default:Date.now}
}); //3、访问todo对象模型
mongoose.model('Todo',TodoSchema); //添加
exports.add=function(title,callback){
var newTodo=new Todo();
newTodo.title=title;
newTodo.save(function(err){
if(err){
console.log(err);
callback(err);
}else{
callback(null);
}
});
} //查找单独的数据
var findTodoById=exports.findTodoById=function(id,callback){
Todo.findOne({_id:id},function(err,doc){
//doc也就是根据id得到的记录值
if(err){
callback(err,null);
}
callback(null,doc);
})
} //删除
exports.delete=function(id,callback){
exports.findTodoById(id,function(err,doc){
if(err){
callback(err);
}else{
doc.remove();
callback(null);
}
})
} //编辑标题
exports.editTitle=function(id,title,callback){
exports.findTodoById(id,function(err,doc){
if(err){
callback(err);
}else{
doc.post_date=new Date();
doc.title=title;
doc.save(function(err){
if(err){
callback(err);
}else{
callback(null);
}
})
}
})
} exports.allTodos=function(callback){
Todo.find({},callback);
} //分页查询
exports.TodoPageList=function(pageIndex,pageSize,callback){
var m=Todo.find({}); //也有方法直接这样写: var m=this;
var start=(pageIndex-1)*pageSize;
m.skip(start);
m.limit(pageSize);
m.sort({'post_date','asc'}); //排序
//根据关键字查询后分页
//m.where('title','XXX'); //执行分页查询
m.exec(function(err,rs){
//分页后的结果
if(err){
callback(err);
}else{
Todo.find(function(err,result){
/*
一般情况下的分页你需要同时返回数据库记录总数和分页后的数据,所以这里使用了Todo.find再查询一次
*/
callback({rows:rs,total:result.length});
});
}
}) }
参考地址
http://www.nodeclass.com/api/mongoose.html#query-js
http://itbilu.com/database/mongo/E1MxCQfS.html#objectId
http://www.cnblogs.com/flyoung2008/archive/2012/07/22/2603791.html
Mongodb 数据类型及Mongoose常用CURD的更多相关文章
- redis基础:redis下载安装与配置,redis数据类型使用,redis常用指令,jedis使用,RDB和AOF持久化
知识点梳理 课堂讲义 课程计划 1. REDIS 入 门 (了解) (操作) 2. 数据类型 (重点) (操作) (理解) 3. 常用指令 (操作) 4. Jedis (重点) (操作) ...
- MongoDB在Linux下常用优化设置
MongoDB在Linux下常用优化设置 以下是一些MongoDB推荐的常用优化设置.在生产环境下选取合适的参数值,例如预读值和默认文件描述符数目等,会对系统性能有很大的影响. 1.关闭数据库文件的 ...
- java 操作mongodb查询条件的常用设置
java操作mongodb进行查询,常用筛选条件的设置如下: 条件列表:BasicDBList condList = new BasicDBList(); 临时条件对象:BasicDBObject c ...
- MongoDB数据类型查询与修改
MongoDB数据类型和对应的代码如下: MongoDB可以根据字段类型进行文档查询: 可以看到,friend集合的文档中,age字段有32位int类型的,也有double类型的.如果需要把doubl ...
- YII 1.0 常用CURD写法
<?php //yii1.0 curd简单写法 //查询 Yii::app()->db->createCommand($sql)->queryAll();//查询所有行数据 ...
- MongoDB 数据类型
MongoDB支持许多数据类型的列表下面给出: String : 这是最常用的数据类型来存储数据.在MongoDB中的字符串必须是有效的UTF-8. Integer : 这种类型是用来存储一个数值.整 ...
- MongoDB (七) MongoDB 数据类型
MongoDB支持许多数据类型的列表下面给出: String : 这是最常用的数据类型来存储数据.在MongoDB中的字符串必须是有效的UTF-8. Integer : 这种类型是用来存储一个数值.整 ...
- MongoDB 安装详细教程 + 常用命令 + 与 Python 的交互
MongoDB 简介 MongoDB (名称来自 humongous/巨大无比的, 是一个可扩展的高性能,开源,模式自由,面向文档的NoSQL,基于 分布式 文件存储,由 C++ 语言编写,设计之初旨 ...
- MongoDB学习之mongoose
MongoDB介绍: MongoDB是基于Javascript语言的数据库,存储格式是JSON,而Node也是基于JavaScript的环境(库),所以node和mongoDB的搭配能减少因为数据转换 ...
随机推荐
- Unity之CharacterController 碰撞问题总结
CharacterController 不会受到scene的重力影响,自带物理碰撞检测,在脱离导航网格的应用场景下(比如飞行),是很有优势的Unity原生工具组件.如果在复杂的应用场景里,会有多种CC ...
- viso
- c#实现redis客户端(一)
最近项目使用中要改造redis客户端,看了下文档,总结分享一下. 阅读目录: 协议规范 基础通信 状态命令 set.get命令 管道.事务 总结 协议规范 redis允许客户端以TCP方式连接,默认6 ...
- Google分布式构建软件之四:分发构建结果
注:本文英文原文在google开发者工具组的博客上[需要FQ],以下是我的翻译,欢迎转载,但请尊重作者版权,注名原文地址. 之前的文章,介绍了Google在分布式构建软件过程中,如何把构建过程分发到许 ...
- 《Entity Framework 6 Recipes》中文翻译系列 (12) -----第三章 查询之使用SQL语句
翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 3-2使用原生SQL语句更新 问题 你想在实体框架中使用原生的SQL语句,来更新底层 ...
- 《Entity Framework 6 Recipes》中文翻译系列 (45) ------ 第八章 POCO之获取原始对象与手工同步对象图和变化跟踪器
翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 8-6 获取原始对象 问题 你正在使用POCO,想从数据库获取原始对象. 解决方案 ...
- 【PRINCE2是什么】PRINCE2认证之七大原则
经过前几讲中关于PRINCE2六大要素,四大步骤及整体思维架构的学习,相信各位看官已经对于PRINCE2有了大概的了解,那我们今天的学习内容会正式进入到七大原则内容的分享. 我们先来回顾一下,PRIN ...
- 操作数据库mysql
显示表结构 desc 表 显示数据库信息 show create database 数据库名 show create table 表名
- iOS 离屏渲染的研究
GPU渲染机制: CPU 计算好显示内容提交到 GPU,GPU 渲染完成后将渲染结果放入帧缓冲区,随后视频控制器会按照 VSync 信号逐行读取帧缓冲区的数据,经过可能的数模转换传递给显示器显示. G ...
- 测试框架Mocha与断言expect
测试框架Mocha与断言expect在浏览器和Node环境都可以使用除了Mocha以外,类似的测试框架还有Jasmine.Karma.Tape等,也很值得学习. 整个项目源代码: 为什么学习测试代码? ...