Mongodb 数据类型及Mongoose常用CURD
数据库  /  管理员 发布于 5年前   159
前言
看完了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
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}); }); } })}
以上内容是小编给大家介绍的Mongodb 数据类型及Mongoose常用CURD ,希望大家喜欢。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号