当前位置: 首页 > 编程笔记 >

Mongodb 数据类型及Mongoose常用CURD

孟谭三
2023-03-14
本文向大家介绍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

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

 类似资料:
  • 主要内容:Object ID,Timestamps,Date下表中列举了 MongoDB 中常用的几种数据类型: 数据类型 描述 String 字符串类型,是最常用的数据类型,不过在 MongoDB 中,只有 UTF-8 编码的字符串才是合法的 Integer 整型,用于存储数值。根据您使用服务器的不同,整型可以分为 32 位或 64 位两种 Boolean 布尔型,用于存储布尔类型的值(true/false) Double 双精度浮点型,用于存储浮点型(

  • 在介绍 Python 的常用数据类型之前,我们先看看 Python 最基本的数据结构 - 序列(sequence)。 序列的一个特点就是根据索引(index,即元素的位置)来获取序列中的元素,第一个索引是 0,第二个索引是 1,以此类推。 所有序列类型都可以进行某些通用的操作,比如: 索引(indexing) 分片(sliceing) 迭代(iteration) 加(adding) 乘(multi

  • 集合(set)和字典(dict)类似,它是一组 key 的集合,但不存储 value。集合的特性就是:key 不能重复。 集合常用操作 创建集合 set 的创建可以使用 {} 也可以使用 set 函数: >>> s1 = {'a', 'b', 'c', 'a', 'd', 'b'} # 使用 {} >>> s1 set(['a', 'c', 'b', 'd']) >>> >>> s2 = se

  • 字典是 Python 中唯一的映射类型,每个元素由键(key)和值(value)构成,键必须是不可变类型,比如数字、字符串和元组。 字典基本操作 这里先介绍字典的几个基本操作,后文再介绍字典的常用方法。 创建字典 遍历字典 判断键是否在字典里面 创建字典 字典可以通过下面的方式创建: >>> d0 = {} # 空字典 >>> d0 {} >>> d1 = {'name': 'ethan',

  • 在 Python 中,元组是一种不可变序列,它使用圆括号来表示: >>> a = (1, 2, 3) # a 是一个元组 >>> a (1, 2, 3) >>> a[0] = 6 # 元组是不可变的,不能对它进行赋值操作 Traceback (most recent call last): File "<stdin>", line 1, in <module> TypeE

  • 字符串和元组是不可变的,而列表是可变(mutable)的,可以对它进行随意修改。我们还可以将字符串和元组转换成一个列表,只需使用 list 函数,比如: >>> s = 'hello' >>> list(s) ['h', 'e', 'l', 'l', 'o'] >>> a = (1, 2, 3) >>> list(a) [1, 2, 3] 本文主要介绍常用的列表方法: index count ap

  • const TYPE_STRING = 0x01; // 字符串 const TYPE_INT = 0x02; // 整型 const TYPE_DOUBLE = 0x04; // 浮点型 const TYPE_TIMESTAMP = 0x08; // 时间戳,可以将 xlsx 文件中的格式化时间字符转为时间戳

  • 本文向大家介绍MyBatis常用的jdbcType数据类型,包括了MyBatis常用的jdbcType数据类型的使用技巧和注意事项,需要的朋友参考一下 MyBatis 通过包含的jdbcType类型 Mybatis中javaType和jdbcType对应和CRUD例子 Mybatis中javaType和jdbcType对应关系 以上所述是小编给大家介绍的MyBatis常用的jdbcType数据类型