MongoDB安装测试和简单使用,Mongoose的安装和使用
MongoDB安装测试和简单使用
1.先安装MongoDB
2.
> mongod --storageEngine mmapv1 --dbpath "d:\mongodb\db" --logpath "d:\mongodb\log\MongoDB.log"
3.测试连接
原来的**cmd窗口不关闭,以管理员身份再开一个cmd窗口**,输入mongo或者mongo.exe,出现如下信息说明测试通过,此时我们已经进入了test这个数据库。
4.**将MongoDB安装为windows服务(重点中的重点)**
当mongod.exe被关闭时,mongo.exe 就无法连接到数据库了,因此每次想使用mongodb数据库都要开启mongod.exe程序,所以比较麻烦,此时我们可以将MongoDB安装为windows服务
以管理员身份运行**cmd**,进入bin文件夹,执行下列命令
mongod --storageEngine mmapv1 --dbpath "d:\mongodb\db" --logpath "d:\mongodb\log\MongoDB.log" --install --serviceName "MongoDB"
5.>输入NET START MongoDB
6.>输入mongo
7.关闭服务和删除进程
先 ctrl+c
关闭服务:net stop MongoDB
MongoDB 常用的命令(重点)
显示数据库列表 > show dbs
创建数据库 > use dbname
1. 增加数据(重点中的重点)
db.web.save({"name":"老李"}) 创建了名为web的集合,并新增了一条{"name":"老李"} 的数据
db.web.insert({"name":"ghost", "age":10}) 在web集合中插入一条新数据,如果没有web这个集合,mongodb会自动创建
save()和insert()也存在着些许区别:若新增的数据主键已经存在,insert()会不做操作并提示错误,而save() 则更改原来的内容为新内容。
2. 删除数据(重点中的重点)
1、删除文档
2、删除集合
3、删除数据库
· db.users.remove({}) 删除users集合下所有数据
· db.users.remove({"name": "lecaf"}) 删除users集合下name=”lecaf”的数据
· db.users.drop()或db.runCommand({"drop":"users"}) 删除集合users
· db.runCommand({"dropDatabase": 1}) 删除当前数据库,注意 此处的1没加双引号。
3. 查找数据(重点中的重点)
· db.users.find() 查找users集合中所有数据
· db.users.findOne() 查找users集合中的第一条数据
· db.users.find().pretty() 格式化查询到的数据
4. 修改数据(重点中的重点)
· db.web.update({"name":"a1"}, {$set: {sex:”women”}},true,true) 修改name=a1的数据为sex=1,第一个参数是查找条件,第二个参数是修改内容,主键不能修改,第三个参数表示匹配所有符合条件的数据,第四个参数表示修改所有匹配到的数据如图
Mongoose的安装和使用
1.1.1. 安装**mongoose**
npm install mongoose
1.1.2. 连接数据库
使用mongoose连接数据库的前提条件是:
1、mongo数据库已经运行。
2、已经安装了mongoose包
var mongoose = require("mongoose");
// 连接字符串格式为mongodb://主机/数据库名
mongoose.connect('mongodb://localhost/student);
上面这句的意思是连接到本地的mongodb的student表。
扩展:
// 连接本地mongodb ,本机的ip 127.0.0.1,端口:27017 数据库:student
mongoose.connect("mongodb://127.0.0.1:27017/student",function(err){
if(!err){//如果连接成功,则打印出connected to Mongodb
console.log("connected to Mongodb");
}else{
throw err;//如果连接失败,则抛出异常
}
});
1.1.3. 新增数据
先讲解一个概念 Schema:
它可以理解为数据库模型骨架,可以看作工厂中模具一样,好比一个茶杯,喝水是茶杯最终的功能,茶杯本身就像是Model,那么茶杯的批量生产是需要靠工厂的模具成型的。Schema不仅定义了文档结构和使用性能,还可以有扩展插件、实例方法、静态方法、复合索引、文档生命周期钩子。
Schema : 一种以文件形式存储的数据库模型骨架,不具备数据库的操作能力 钱的电板
Model : 由Schema发布生成的模型,具有抽象属性和行为的数据库操作对 钱的样板
Entity : 由Model创建的实体,他的操作也会影响数据库 钱
存储数据步骤:定义Schema (骨架) > 创建model(模型)> Entity实例化方法。
var Schema = mongoose.Schema;
//通过Schema创建一个模式NewsSchema
var studentSchema = new Schema({
name: String,
age: String
});
student*Schema 类型有哪些*
//通过模式studentSchema 创建一个模型studentModel
var studentModel = mongoose.model("students",studentSchema );
var instance1 = new studentModel ();
instance1.name="tangyan";
instance1.age="18";
//通过save方法保存
instance1.save(function(err){
if (err) {
console.log('保存失败');
return;
}
});
1.1.4. 删除数据
思路:
1、删除数据首先要知道删除哪一条信息,需要知道信息的id.
2、把对应id的数据查询出来,执行remove方法
假如我们要删除id=”57e24521a755e1154039a403”的数据。
var id=”57e24521a755e1154039a403”;
studentQueryModel.findById(id,function(err,doc){
if(!doc){
return next(new NotFound("Doc not found"))
}else{
doc.remove(function(){
console.log('删除成功');
})
}
});
1.1.5. 修改数据
修改数据的思路:先把对应id的数据查询出来,对需要修改的字段重新赋值,然后执行save方法保存。
假如我们要修改id=”57e24521a755e1154039a403”的数据。
var id=”57e24521a755e1154039a403”;
studentQueryModel.findById(id,function(err,doc){
//console.log(doc);
doc.name="xiaotangyan" ;//把name修改为xiaotangyan
doc.save(function(err){
if(!err){
console.log('修改成功');
}else{
throw err;
}
});
});
1.1.6. 查询数据
下面find第一个参数{}里面为空,表示查询所有的数据:
docs表示查询的结果集合,可用于渲染ejs模板引擎。
studentQueryModel.find({},function(err,docs){
console.log(docs);
});
2. 需求分析
为了保存网站的数据,通常需要一个数据库。MongoDB和Node.js特别般配,因为MongoDB是基于文档的非关系型数据库,文档是按BSON(JSON的轻量化二进制格式)存储的,增删改查等管理数据库的命令和JavaScript语法很像。如果你在Node.js里访问MongoDB的数据,会有我们是一家人的感觉,特别亲切。