第一章、mongodb入门
一、什么是MongoDB
MongoDB是一个介于关系数据库和非关系数据库(nosql)之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。
MongoDB是开源,高性能的NoSQL数据库,支持索引、集群、复制和故障转移、各种语言的驱动程序丰富;
MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。
MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。
MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。
MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。
二、MongoDB的安装
1、下载MongoDB
可以从官网下载安装,下载地址:MongoDB官网。
2、安装
下载成功后点击msi文件直接next,这里以Windows操作系统为例。
3、环境配置
安装文件里面有两个主要的部分:mongod.exe和mongo.exe,分别为服务器和操作后台。如果要成功运行MongoDB,需要先搭建并运行服务器,其次在保持服务器运行的情况下再打开后台。
由于前期的安装不会生成数据目录,需要自己创建。打开cmd,在D盘创建数据文件夹,如D:datadb用于存放mongodb的数据文件,也可使用Windows自带的界面在D盘右键创建。
运行cmd,打开安装目录下的bin文件,在bin目录中执行mongod.exe文件。输入如下:
保持之前的cmd窗口,再打开一个cmd窗口来运行mongo.exe,同样打开bin文件,执行mongo.exe,就可以进入MongoDB的Shell界面。
至此,MongoDB安装完毕,然后就可以使用命令行操作数据库了。
4、把MongoDB服务器作为Windows服务运行
将MongoDB服务器安装为Windows服务,可以避免每次使用MongoDB都要开启mongod.exe程序,当mongod.exe被关闭时,mongo.exe 就无法连接到数据库的问题。
1)打开MongoDB的安装目录如“D:Program FilesMongoDBServer3.6in”,并在此目录下新建一个mongo.config文件,文件内容如下:
##数据库目录##
dbpath=C:datadb
##日志输出文件##
logpath=C:datalogdb.log
2)cmd进入命令行,使用cd切换目录到安装目录,如:cd D:Program FilesMongoDBServer3.6in
安装MongoDB服务且指定配置文件,如:mongod --config "D:Program FilesMongoDBServer3.6inmongo.config" --install
3)启动服务
启动服务:net start mongodb
停止服务:net stop mongodb
打开任务管理器可以看到MongoDB已经启动
把MongoDB服务器作为Windows服务运行之后,就不用再启动MongoDB的服务器,直接运行mongo.exe操作后台程序就可以使用。
三、数据库的基本操作
1、基本概念
在MongoDB中基本的概念是文档、集合、数据库。
2、基本操作
创建数据库:
- 语法:use database_name
- 示例:use DB_Demo
如果数据库不存在,则创建数据库,否则切换到指定数据库。
要显示刚创建的数据库需要向 数据库插入一些数据。
删除数据库:
- 语法:db.dropDatabase()
- 示例:先切换到数据库 DB_Demo,再执行删除操作。(可以使用 db 命令查看当前数据库名,防止误操作)
use DB_Demo
db.dropDatabase()
创建集合:
- 语法:db.createCollection(name, options)
- 示例:先切换到数据库 DB_Demo并创建users集合
use DB_Demo
db.createCollection("users")
删除集合:
- 语法:db.collection.drop()
- 示例:db.user.drop()
插入文档:
- 语法:db.collection_name.insert(document)
- 示例:db.users.insert({name:'zhangsan',age:18})
- 语法:db.collection_name.save(document)
- 示例:db.users.save({name:'lisisi',age:16})
说明:insert和save方法都可以插入数据,当默认的“_id”值已存在时,调用insert方法插入会报错;而save方法不会,会更新相同的_id所在行数据的信息。
- 语法:db.collection_name.insertOne(document)
- 说明:向指定集合中插入一条文档数据
- 语法:db.collection_name.insertMany(document)
- 说明:向指定集合中插入多条文档数据(注意是数组)
- 示例:db.users.insertMany([{name:'wangsansan',age:'22'},{name:'zhanglili',age:21}])
删除文档:
- 语法:db.collection_name.remove(条件)
- 示例: db.users.remove({'name':'zhangsan'})
- 语法:db.collection_name.deleteOne(条件)
- 说明: 删除 指定条件的一个文档
- 语法:db.collection_name.deleteMany(条件)
- 说明: 删除 指定条件的全部文档
修改文档:
- 语法:db.collection_name.update({"条件字段名":"字段值"},{$set:{"要修改的字段名":"修改后的字段值"}})
- 说明: 只修改第一条发现的文档
- 示例:db.users.update({'name':'zhangsan'},{$set:{'name':'wanger'}})
- 语法:db.collection_name.update({"条件字段名":"字段值"},{$set:{"要修改的字段名":"修改后的字段值"}},{multi:true});
- 说明: 修改多条相同的文档,需要设置 multi 参数为 true。
查询文档:
- 查询集合中所有数据:db.collection_name.find(); 例:db.users.find().pretty()
- 按条件查询(支持多条件):db.collection_name.find(条件); 例:db.users.find({name:'zhangsan'});
- 限制数量:db.collection_name.find().limit(数量);
- 跳过指定数量:db.collection_name.find().skip(数量);
- 查询第一条(支持条件):db.collection_name.findOne(条件);
- 查询数量:db.collection_name.find().count();
- 排序:db.collection_name.find().sort({"字段名":1}); 1:表示升序,-1:表示降序
- 指定字段返回: db.collection_name.find({},{"字段名":0}); 1:返回 0:不返回
常用命令:
- 使用 db 命令查看当前数据库名
- 查看所有数据库,可以使用 show dbs 命令
- 查看已有集合,可以使用 show collections 命令
- find() 方法以非结构化的方式来显示所有文档,语法:db.collection_name.find()
- 以易读的方式来读取数据使用 pretty() 方法,语法:db.collection_name.find().pretty()
- use database_name如果数据库不存在,则创建数据库,否则切换到指定数据库
四、其它注意事项
1、数据库命名规则:
- 不能是空字符串
- 不能含有空格、.、$、/、和 (空字符)
- 应全部小写
- 最多64字节
2、保留数据库
有一些数据库名是保留的,可以直接访问这些有特殊作用的数据库
- admin:’root‘数据库,要是将一个用户添加到这个数据库,这个用户自动继承所有数据库的权限,一些特定的服务器端命令也只能从这个数据库运行,比如列出所有的数据库或者关闭服务器
- local:这个数据库永远不会被复制,可以用来存储于本地单台服务器的任意集合
- config:当mongoDB用于分片设置时,config数据库在内部使用,用于保存分片的相关信息
五、可视化工具GUI
1、MongoDB可视化工具
MongoDB安装完成后会有一个可视化工具,如图,可以点击连接到本地数据库,查看本地的数据库名称,以及创建数据库,删除数据库等操作。
点击连接后会列出当前存在的数据库列表。
2、第三方可视化工具
下载地址:robomongo官方网站
第二项是一个绿色版,解压后在文件夹中找到exe文件直接运行即可。
运行后连接到本地数据库,右键打开shell脚本编写界面可以执行MongoDB相关命令,执行快捷键F5或Ctrl+Enter。
第二章、mongodb实战
linux 环境搭建
MongoDB 官方提供了各种 linux 的发行版本,强烈建议你去官方下载,不要从乱七八糟的渠道下载乱七八糟的安装包。
下载地址:https://www.mongodb.com/download-center#community
安装过程(基于 Ubuntu - 16.04 - 64位)
curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.0.6.tgz # 下载
tar -zxvf mongodb-linux-x86_64-3.0.6.tgz # 解压
mv mongodb-linux-x86_64-3.0.6/ /usr/local/mongodb # 将解压包拷贝到指定目录
export PATH=/usr/local/mongodb/bin:$PATH # 添加到 PATH 路径
创建数据库目录
数据库目录在安装过程中不会自动创建,需要你手动找一个你觉得合适的地方创建 data 目录。
sudo mkdir -p /data/db # 我选择创建在根目录下
划重点 :/data/db
是 MongoDB 默认的启动的数据库路径。
如果你觉得放在根目录下不爽,可以通过 --dbpath
来指定。
mongod --dbpath <其他目录> # <其他目录> 替换成你觉得爽的数据目录
MongoDB后台管理 Shell
输入命令 mongo
。
当你进入 mongoDB 后台后,它默认会链接到 test 数据库。
# mongo
MongoDB shell version: 2.6.10
connecting to: test
>
基本概念
文档
文档是 MongoDB 中数据的基本单元,理解起来很简单,就是一组数据有序的放在一起就是文档。
例如:
单键值文档 {"userName":"WuJiaYi"}
多键值文档 {"_id" : ObjectId("58097dfe7e6d64baca4847365"), "name" : "WuJiaYi", "add" : "China" }
集合
多个文档放在一起就是集合。
数据库
多个集合放在一起就是数据库。
关系如下图所示:
shell 部分命令表
show dbs
显示所有数据库。
> show dbs # 新创建的数据库不会显示。需要写入一些数据,才会显示。
admin (empty)
local 0.078GB
test 0.078GB
>
db
显示当前数据库。
> db
test
>
use
切换 或 创建数据库。
> use local # 如果数据库不存在,则创建数据库,否则切换到指定数据库。
switched to db local
> db
local
>
db.dropDatabase()
删除数据库。
> use test # 切换到 test 数据库
switched to db test
> db.dropDatabase() # 删除当前的数据库
{ "dropped" : "test", "ok" : 1 }
> show dbs # test 数据库被删除了
admin (empty)
local 0.078GB
>
db.createCollection("NAME")
创建集合。
> db.createCollection("test")
{ "ok" : 1 }
>
show collections
显示当前数据库的集合。
> show collections
system.indexes
wujiayi
wweeww
>
db.NAME.drop()
删除集合。
> show collections # 显示所有集合
system.indexes
wujiayi
wweeww
> db.wujiayi.drop() # 删除 wujiayi 这个集合
true
> show collections # wujiayi 集合已经被删除了
system.indexes
wweeww
>
db.COL_NAME.insert(DOC)
插入文档。
>db.col.insert({title: 'MongoDB 手册',
name: '吴佳轶',
url: 'http://www.wujiayi.vip',
add: 'Beijing',
})
db.COL_NAME.update(DOC)
更新文档。
>db.col.update({'title':'MongoDB 教程'},{$set:{'title':'MongoDB'}},{multi:true}) # col是集合的名字
db.COL_NAME.remove(DOC,NUMBER)
删除文档。
>db.col.remove({'title':'MongoDB'},1) # 查找符合 title 为 MongoDB 的文档,删除一条。
WriteResult({ "nRemoved" : 1 }) # 删除了两条数据
db.COL_NAME.find().pretty()
查询所有文档。
> db.col.find().pretty() # 格式化查询所有文档
> db.col.findOne() # 查询一条数据
> db.col.find() # 非格式化查询
Node.js 连接 MongoDB
创建数据库
如果数据库不存在则创建。
var MongoClient = require('mongodb').MongoClient;
var url = "mongodb://localhost:27017/WuJiaYi";
MongoClient.connect(url, function(err, db) {
if (err) throw err;
console.log("数据库已创建!");
db.close();
});
创建合集
var MongoClient = require('mongodb').MongoClient;
var url = 'mongodb://localhost:27017/WuJiaYi';
MongoClient.connect(url, function (err, db) {
if (err) throw err;
console.log('数据库已创建');
var dbase = db.db("WuJiaYi");
dbase.createCollection('data', function (err, res) {
if (err) throw err;
console.log("创建集合!");
db.close();
});
});
插入数据
var MongoClient = require('mongodb').MongoClient;
var url = "mongodb://localhost:27017/";
MongoClient.connect(url, function(err, db) {
if (err) throw err;
var dbo = db.db("WuJiaYi");
var myobj = { name: "吴佳轶", url: "www.wujiayi.vip" };
dbo.collection("data").insertOne(myobj, function(err, res) {
if (err) throw err;
console.log("文档插入成功");
db.close();
});
});
插入多条数据
var MongoClient = require('mongodb').MongoClient;
var url = "mongodb://localhost:27017/";
MongoClient.connect(url, function(err, db) {
if (err) throw err;
var dbo = db.db("WuJiaYi");
var myobj = [
{ name: '吴佳轶', url: 'http://www.wujiayi.vip', type: 'cn'},
{ name: '魔法世界', url: 'http://www.magicworld.vip', type: 'ch'},
{ name: '魔法学校', url: 'http://www.magicshool.vip', type: 'ch'}
];
dbo.collection("data").insertMany(myobj, function(err, res) {
if (err) throw err;
console.log("插入的文档数量为: " + res.insertedCount);
db.close();
});
});
查询数据
var MongoClient = require('mongodb').MongoClient;
var url = "mongodb://localhost:27017/";
MongoClient.connect(url, function(err, db) {
if (err) throw err;
var dbo = db.db("WuJiaYi");
dbo.collection("data"). find({}).toArray(function(err, result) { // 返回集合中所有数据
if (err) throw err;
console.log(result);
db.close();
});
});
查询指定条件的数据
var MongoClient = require('mongodb').MongoClient;
var url = "mongodb://localhost:27017/";
MongoClient.connect(url, function(err, db) {
if (err) throw err;
var dbo = db.db("WuJiaYi");
var whereStr = {"name":'吴佳轶'}; // 查询条件
dbo.collection("data").find(whereStr).toArray(function(err, result) {
if (err) throw err;
console.log(result);
db.close();
});
});
更新数据
var MongoClient = require('mongodb').MongoClient;
var url = "mongodb://localhost:27017/";
MongoClient.connect(url, function(err, db) {
if (err) throw err;
var dbo = db.db("WuJiaYi");
var whereStr = {"name":'吴佳轶'}; // 查询条件
var updateStr = {$set: { "url" : "http://wujiayi.vip" }};
dbo.collection("data").updateOne(whereStr, updateStr, function(err, res) {
if (err) throw err;
console.log("文档更新成功");
db.close();
});
});
更新多条数据
var MongoClient = require('mongodb').MongoClient;
var url = "mongodb://localhost:27017/";
MongoClient.connect(url, function(err, db) {
if (err) throw err;
var dbo = db.db("WuJiaYi");
var whereStr = {"type":'ch'}; // 查询条件
var updateStr = {$set: { "url" : "http://www.magicworld.vip" }};
dbo.collection("data").updateMany(whereStr, updateStr, function(err, res) {
if (err) throw err;
console.log(res.result.nModified + " 条文档被更新");
db.close();
});
});
删除数据
var MongoClient = require('mongodb').MongoClient;
var url = "mongodb://localhost:27017/";
MongoClient.connect(url, function(err, db) {
if (err) throw err;
var dbo = db.db("WuJiaYi");
var whereStr = {"name":'吴佳轶'}; // 查询条件
dbo.collection("data").deleteOne(whereStr, function(err, obj) {
if (err) throw err;
console.log("文档删除成功");
db.close();
});
});
删除多条数据
var MongoClient = require('mongodb').MongoClient;
var url = "mongodb://localhost:27017/";
MongoClient.connect(url, function(err, db) {
if (err) throw err;
var dbo = db.db("WuJiaYi");
var whereStr = { type: "en" }; // 查询条件
dbo.collection("data").deleteMany(whereStr, function(err, obj) {
if (err) throw err;
console.log(obj.result.n + " 条文档被删除");
db.close();
});
});