在使用node和AngularJS进行项目开发时,只知道数据库不是平常所使用的的mysql或者SqlServer,而是robmongoose,所以对于MongoDB、robmongoose和mongoose三者的关系一直是云里雾里,只知道项目用的是robmongoose,所以现在就来讨论一下三者的关系:
首先MongoDB是一种数据库,相当于mysql,SqlServer一类的数据库。
robmongoose是MongoDB的可视化界面,相当于mysql的Navicat。只是让操作数据库更简单明了一些,更人性化。
mongoose是mongoDB的一个对象模型工具,是基于node-mongodb-native开发的mongoDB的nodejs驱动,可以在异步的环境下执行。同时它也是针对mongoDB操作的一个对象模型库,封装了mongoDB对文档的一些增删改查等常用方法,
简单点来说,mongoose让nodejs操作mongoDB数据库变得更加容易。
mongoDB与一些关系型数据库相比,它更显得轻巧、灵活,非常适合在数据规模很大、事务性不强的场合下使用。同时它也是一个对象数据库,没有表、行等概念,也没有固定的模式和结构,所有的数据以文档的形式存储。
·由c++语言编写,是一个分布式文件存储的开源NoSQL数据库系统。在高负载的情况下,添加更多的节点,可以保证服务器性能。
· mongoDB旨在为web应用提供可扩展的高性能数据存储解决方案
· mongoDB将数据存储为一个文档,数据结构由键值对组成。mongoDB文档类似于JSON对象,字段值可以包含其他文档、数组及文档数组。
接下来就看一下mongoose的一些常用操作:
1.安装mongoose:
npm install mongoose
- 引用mongoose
var mongoose = require(‘mongoose’);
3.使用mongoose连接数据库
var db = mongoose.connect(‘mongodb://user:pass@localhost:port/database’)
如我的是
var db = mongoose.connect(‘mongodb://localhost/TTMS’);
4.检查数据库是否正常连接:
//4.1加载模块
var mongoose = require(‘mongoose’);
//4.2创建一个名为TTMS的数据库
var db = mongoose.connect(‘mongodb://localhost/TTMS’);
//4.3连接失败会执行回调
db.connection.on(‘error’, function(error){
console.log(‘数据库连接失败:’+error);
});
//4.4如果连接成功会执行回调
db.connection.on(‘open’, function(){
console.log(‘数据库连接成功!’);
});
//5.定义一个 schema,描述此集合里有哪些字段,字段是什么类型
只有schema中有的属性才能被保存到数据库中.
var schema = new mongoose Schema({
id:Number,
name:String,
director:String,
actor:String,
direction:String,
});
//创建模型,可以用它来操作数据库中的person集合,指的是整体
var movieModel = db.model('Movies', schema);
//根据模型创建实体,是指的个体对象
var moviesEntity = new movieModel({
id:1,
name:'速度与激情8',
director:'aaa',
actor:'aaaaaaaaa',
direction:'aaaa',
});
//用save 方法把自己保存到数据库中
moviesEntity.save(function(error,doc){
if(error){
console.log("error :" + error);
}else{
console.log(doc);
}
});
然而上述用到了Scheme,Scheme是什么?
这是一种以文件形式存储的数据库模型骨架,无法直接通往数据库端,也就是说它不具备对数据库的操作能力,仅仅只是数据库模型在程序片段中的一种表现,可以说是数据属性模型(传统意义的表结构),又或者是集合的模型骨架。基本属性类型有字符串、日期型、数值型、布尔型、null、数组、内嵌文档等。
定义一个Schema:
var schema = new mongoose Schema({
id:Number,
name:String,
director:String,
actor:String,
direction:String,
});
Model简述
由Schema构造生成的模型,除了Schema定义的数据库骨架以外,还具有数据库操作的行为,类似于管理数据属性、行为的类。
通过Schema创建Model
//创建模型,可以用它来操作数据库中的person集合,指的是整体。创建一个person集合
var movieModel = db.model(“Movies”, schema);
Movies:数据库中的集合名称,当我们对其添加数据时如果Movies已经存在,则会保存到其目录下,如果未存在,则会创建Movies集合,然后再保存数据。有了model,也就有了操作数据的能力。创建一个Model模型,需要指定两点:1,集合名称;2,集合的Schema结构对象。满足这两点,就可以操作数据库啦。
Entity简述
由Model创建的实体,使用save方法保存数据,Model和Entity都有能影响数据库的操作,但Model比Entity更具操作性。创建Entity成功后,Schema的属性就变成了Model和Entity的公共属性了。
使用Model创建Entity
复制代码
//根据模型创建实体,是指的个体对象
var moviesEntity = new movieModel({
id:1,
name:'速度与激情8',
director:'aaa',
actor:'aaaaaaaaa',
direction:'aaaa',
});