各位用户为了找寻关于Mongodb 数据类型及Mongoose常用CURD的资料费劲了很多周折。这里教程网为您整理了关于Mongodb 数据类型及Mongoose常用CURD的相关资料,仅供查阅,以下为您介绍关于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?
MongoDB 是一个开源的 NoSQL 数据库,相比 MySQL 那样的关系型数据库,它更为轻巧、灵活,非常适合在数据规模很大、事务性不强的场合下使用。
Mongoose
Mongoose是封装了MongoDB的操作的一个对象模型库,为nodejs而生。就好像我们嫌原生javascript难写,代码量多,于是用jQuery库一样,因为MongoDB的操作接口复杂,不人性,所以有了Mongoose。这个库完全是可选的。 Mongoose的使用非常简单,在App的package.js中的dependence中加入mongoose,然后 npm install 即可。
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
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91var
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});
});
}
})
}
以上内容是小编给大家介绍的Mongodb 数据类型及Mongoose常用CURD ,希望大家喜欢。