MongoDB是一个基于分布式文件储存的数据库,目前是世界上用的最多的非关系型数据库,也是最像关系型的非关系型数据库。
MongDB以BSON(二进制+JSON)格式进行数据存储。

1.MongoDB 下载与安装

MongoDB 官网地址
https://www.mongodb.com/ MongoDB 下载地址
https://www.mongodb.com/download-center/community MongoDB for Windows 64-bit 适合64位Windows Server 2008 R2,Windows 7,及最新版本的Window系统。

2.MongoDB 文件

mongodb数据库默认字段 mongodb默认的数据库_数据库

2.MongoDB 设置环境变量

form:

3.创建文件夹

在非系统盘创建文件夹:E:\zjx\lianxi\data
E:\zjx\lianxi\data\db 用于存放数据库
E:\zjx\lianxi\data\log 用于存放日志文件

4.将MongoDB安装为windows服务(重点中的重点)

当mongod.exe被关闭时,mongo.exe就无法连接到数据库了,因此每次想使用MongoDB数据库都要开启mongod.exe程序,所以比较麻烦,此时我们可以将MongoDB安装为Windows服务。

以管理员身份运行cmd,进入bin文件夹,执行下列命令:

mongod --dbpath “E:\zjx\lianxi\data\db” --logpath “E:\zjx\lianxi\data\log\MongoDB.log” --install --serviceName "MongoDB"
32位系统要加 --storageEngine mmapv1 选择mmapv1存储引擎
这里MongoDB.log就是开始建立的日志文件,–serviceName “MongoDB” 服务器命名为MongoDB

接着启动mongodb服务 >NET START MongoDB
补充:
mongodb是服务器名称
net stop mongodb 关闭服务
sc delete mongodb 卸载服务器

5.数据库基础命令

数据库 =》 集合 =》 文档

1.进入数据库管理模式

在命令行中运行 mongo 进入数据库管理模式
在数据库管理模式中只能执行数据库命令,不能执行其他命令
exit 可以退出数据库管理模式

2.常用数据库命令

a.显示所有数据库列表 show dbs
b.创建数据库命令/进入数据库命令 use + 数据库名
//如果数据库名不存在则创建数据库,如果数据库存在则进入数据库。
c.查看当前数据库 db
d.删除数据库 db.dropDatebase();

3.集合的命令

a.显示当前数据库中的所有集合 show collections
b.创建集合 db.集合名.insert({});
//通常,在创建数据时自动创建集合,不需要单独创建
c.删除集合 db.集合名.drop();

4.文档(数据)的命令(重点中的重点)

a.新增文档(数据)

db.集合名.insert({BSON数据});
db.集合名.save({BSON数据});
例如:

db.user.insert({“name”:“admin”,“password”:“123456”});
 db.user.insert({“name”:“张三丰”,“age”:“1000”});
 db.list.insert({“name”:“刘备”,“age”:“29”});

insert和save方法的区别:
.insert() 向集合中插入一条数据 (推荐使用)
.save() 向集合中添加一条数据,如果集合中已存在该条数据则更新

b.查看文档(数据)

db.集合名.find(); //查找当前集合中的所有数据
db.集合名.find({条件对象}); //查找当前集合中的所符合条件的数据
db.集合名.findOne(); //查找第一条数据 或 按_id查询
db.集合名.find().pertty(); //将找到的数据按格式化显示出来

c.修改文档(数据)

db.集合名.update(查找对象,修改结果)
db.集合名.update({“name”:“a1”},{“age”:10})
修改name为a1的数据中所有数据都改为{“age”:10}

db.集合名.update({“name”,“a1”},{$set:{“age”:10}})
$set 修改其中的一节
修改name为a1的数据中age的值为10

d.删除文档(数据)
db.user.remove({}) 删除user集合下所有数据
db.user.remove({“name”,“张三丰”}) 删除user集合name="张三丰"的数据

注意:由于删除和更新操作会对数据造成极大影响,所以一定要谨慎!谨慎!再谨慎!!更新和删除之前先备份!!!!

5.文档(数据)的高级命令(重点中的重点)

1.按指定条件查询
//需求:查找所有的女歌星
db.singer.find({“sex”:“女”});
//SQL:select * form singer where sex=“女”

//需求:查找所有的中国男歌手
国籍:中国
性别:男
db.singer.find({“country”:“中国”,“sex”:“男”});
//SQL:select * form singer where country=“中国” and sex=“男”

2.大于
语法:db.集合名.find({字段名,{$gt:值}})
//需求:年龄大于50岁的歌星
db.singer.find({“age”,{ $gt:50}})
//SQL:select * from singer where age>50

3.大于等于
语法:db.集合名.find({字段名,{$gte:值}})
//需求:年龄大于等于50岁的歌星
db.singer.find({“age”,{ $gte:50}})
//SQL:select * from singer where age>=50

4.小于
语法:db.集合名.find({字段名,{$lt:值}})
//需求:年龄小于30岁的歌星
db.singer.find({“age”,{ $lt:30}})
//SQL:select * from singer where age<50

5.小于等于
语法:db.集合名.find({字段名,{$lte:值}})
//需求:年龄小于等于30岁的歌星
db.singer.find({“age”,{ $lte:30}})
//SQL:select * from singer where age<=50

6.查询指定范围的数据
语法:db.集合名.find({字段名,{$gt:小值, $lt:大值}})
//需求:年龄30-40岁之间的歌星
db.singer.find({“age”,{ $gt:30, $lt:40}})
//SQL:select * from singer where age>30 and age<40
//SQL:select * from singer where age>30 and age<40

7.查询不符合条件的数据
语法:db.集合名.find({字段名,{$ne:值}})
//需求:查询外国歌手,条件为country不为“中国”
db.singer.find({“country”,{ $ne:“中国”}})
//SQL:select * from singer where age>30 and age<40

8.$ in 字句
语法:db.集合名.find({字段名,{$in:[值1,值2,值3]}})
//需求:找出刘德华 张学友 郭富城
db.singer.find({“name”,{ $in:[“刘德华”,“张学友”,“郭富城”]}})
//SQL:select * from singer where name in (‘刘德华’,‘张学友’,‘郭富城’)

9.$ size 字句
语法:db.集合名.find({字段名,{$size:数值}})
字段名所对应的必须为数组
//需求:找出有3个代表作的歌手
db.singer.find({“works”:{ $size:3}})
//SQL:不能存放数组

10.$ exists字句
语法:db.集合名.find({字段名,{$exists:true|false}})
判断字段是否存在
$exists字段存在 true返回存在的字段数据,false返回不存在字段的数据

11.$ or字句
$ or 查找多条件时,符合其中之一就找出来
语法:db.集合名.find({$or:[{“字段名1”:值},{“字段名2”:值}]})
//需求:某个娱乐公司15个人,资料都在数据库里,某个活动必须要刘德华参加,另外需要团队的全部女歌手配合演出。查询符合条件的歌手资料
db.singer.find({ $or:[{“name”:“刘德华”},{“sex”:“女”}]})
//SQL:select * from singer where name=“刘德华” or sex=“女”

12.排序
语法:db.集合名.find({}).sort({“key1”:1,“key2”:-1})
说明:1是升序,-1是降序 key1条件相同时按住key2排序
//需求:歌手按照年龄降序排序 年龄相同时按分数升序排列
db.singer.find({}).sort({“age”:-1,“score”:1})

13.限定输出 limit() skip()
.limit(数字) //限定输出数据的条数
.skip(数字) //跳过指定的数据条数
主要用于做分页
//需求:只查找年龄最大的3个人
db.singer.find({}).sort({“age”:-1}).limit(3);
//需求:查找年龄在第三第四第五的人
db.singer.find({}).sort({“age”:-1}).skip(2).limit(3)

14.模糊查询
语法:db.集合名.find({“字段名”:/值/})
//需求:查询名字中带刘的歌星
db.singer.find({“name”:/刘/}

6.mongoose的安装及使用

1.什么是mongoose?
mongose是一个基于node.js的用于操作MongoDB数据库的第三方模块

2.mongoose的安装
先安装express框架
$ npm install mongoose

3.mongoose的使用
a.链接数据库

mongoose.connect(“mongodb:127.0.0.1:27017/数据库名”,function(err){
 if(err){
 throw err;
 }else{
 console.log(“数据库链接成功”);
 };
 });

b.定义骨架 Schema
Schema概念:它可以理解为数据库模型骨架,可以看做工厂中的模具一样,好比一个茶杯,喝水是茶杯最终的功能,茶杯本身就像是Model,name茶杯的批量生产是需要靠工厂的模具成型的。Schema不仅定义了文档结构和使用性能,还可以扩展插件、实例方法、静态方法、符合索引、文档生命周期钩子。

Schema:一种以文件形式储存的数据库模型骨架,不具备数据库的操作能力。
Model:由Schema发布生成的模型,具有抽象属性和行为的数据库操作。
Entity:由Model创建的实体,他的操作也会影响数据库。

储存数据步骤:定义Schema(骨架)=>创建model(模型)=>Entity实例化方法。

语法:var schema = new mongoose.Schema({
字段名:类型,
字段名:类型.
})
类型:String Number Date Buffer(缓存、二进制) Boolean Mixed(混合类型) ObjectId Array(数组)
实例:

var singerSchema = new mongoose.Schema({
 name:String,
 country:String,
 age:Number
 })

c.创建模型model
概述:model模型是一种根据骨架创建出来的模型,具备数据库操作能力,通常用于读取数据库数据
语法:var singerModel = mongoose.model(“模型名称”,“骨架”,“集合名称”);
模型名称和集合名称保持一致,提高稳定性
实例:var singerModel = mongoose.model(‘singer’,‘singerSchema’,‘singer’)

d.创建实体entity
概述:Entity实体是根据模型创建出一个实例,具备数据库操作的能力,通常用于写数据(新增、修改、删除)
实例:var singer = new singerModel();
singer.属性名=值;
singer.属性名=值;
singer.属性名=值;

singer.save();//将添加实例上的属性保存到数据库
singer.remove();//删除数据

7.增删改查(数据操作)

1.读取数据/查询数据
方法1:根据条件进行数据查询,可以找出多条数据
模型.find({条件},function(err,data){
//data是从数据库中读取到的数据
//find方法找出的数据一定是个数组,即使没有数据也是一个空数组
})

方法2:查找一条数据
模型.findById(‘id’,function(){
//findById找出来的数据是一个对象
})

方法3:链式调用exec(为了实现查询条件+顺序)
模型.find({}).skip().limit().exec(function(){
//data是从数据库中读取到的数据
})

2.新增数据
var list = new listModel();//按照模型创建实体
list.name=“张三”;
list.age=18;
list.save(function(err){
console.log(“新增成功!”)
});//将新增的数据保存到数据库中
注意:如果骨架中没有定义属性及类型,是不能加进数据库。

3.删除数据
思路:
第一步:先找出要删除的数据。
第二步:调用实体上的remove()方法
实例:

listModel.findById(id).exec(funcition(err,data){
 data.remove(function(err){
//console.log(“删除成功”);
 data.remove(function (err) {
 res.send("

"+id+“已删除

”)


});


})


})

4.修改数据
思路:
第一步:找出被修改的数据
第二部:将数据修改后保存回数据库

实例:

listModel.findById(id).exec(funcition(err,data){
 data.name=新的值;
 data.age=新的值;
 data.save(function (err) {
 res.send(“

修改成功

”)


});


})