好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

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

91

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 ,希望大家喜欢。

查看更多关于Mongodb 数据类型及Mongoose常用CURD的详细内容...

  阅读:28次