SQL ServerMongodb 数据类型及Mongoose常用CU福睿斯D

常见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});
            });
        }
    })

}

  

前言

     
看完了Node.js实战,在那之中在数量存款和储蓄部分涉及了Redis、Mongodb,作者自身也依照书中的介绍写了多少个简易的demo,在demo的经过首先碰着的难题正是数据类型和广大的CU兰德酷路泽D写法。
mongodb的周边操作有三种艺术,2个是一直利用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}。

    ③ 、数据类型。在Mongodb
Shell中默许使用六十四个人浮点型数据,如{“x”:2.32}、{“x”:2},即便要动用整数类型则用{“x”:NumberInt(2)}、{“x”:NumberLong(2)}。

    四 、字符串。Mongodb中字符串采取UTF-8编码方式,{“x”:”hello world”}。

    伍 、日期类型。{“x”:new Date()}。

    六 、正则表明式。 Mongodb中可采纳和javascript相同的正则表达式
{“x”:/itbilu/i}。

   
七 、数据。Mongodb中数组的利用和javascript相同{“x”:[“hello”,”world”]}。

    ⑧ 、内嵌文书档案。{“x”:{“y”:”Hello”}}。

   
⑨ 、Id和ObjectId()。Mongodb各个文书档案都会包罗三个_id,假设你不点名时Mongodb会自动生成贰个ObjectId对象。

    10、代码。{“x”:function aa(){}}。

    11、二进制。

参照地址

   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

相关文章