* 1. 简介
* 推荐理由
* MongoDB 是一个基于分布式的开源文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。
* MongoDB是一个介于关系数据库和非关系数据库之间的产品, 是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似json的bjson格式,因此可以存储比较复杂的数据类型。 Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。
* 分布式优缺点
* 优点
* 可靠性(容错) :
* 分布式计算系统中的一个重要的优点是可靠性。一台服务器的系统崩溃并不影响到其余的服务器。
* 可扩展性:
* 在分布式计算系统可以根据需要增加更多的机器。
* 资源共享:
* 共享数据是必不可少的应用,如银行,预订系统。
* 灵活性:
* 由于该系统是非常灵活的,它很容易安装,实施和调试新的服务。
* 更快的速度:
* 分布式计算系统可以有多台计算机的计算能力,使得它比其他系统有更快的处理速度。
* 开放系统:
* 由于它是开放的系统,本地或者远程都可以访问到该服务。
* 更高的性能:
* 相较于集中式计算机网络集群可以提供更高的性能(及更好的性价比)。
* 不管我们学习什么数据库都应该学习其中的基础概念,在mongodb中基本的概念是 数据库/集合/文档
data:image/s3,"s3://crabby-images/d2791/d27913288eac5f1510d79792554c0717677d8c31" alt="image"
* 例子
* SQL
* id user_name email age
* 1 A ab@163.com 25
* 2 b bb@163.com 32
* MongoDB
* {
* "_id":ObjectId("1234567890123456789012f3"),
* "user_name":"A",
* "email":"ab@163.com"
* "age":25
* }
* {
* "_id":ObjectId("1234567890123456789012f2"),
* "user_name":"b",
* "email":"bb@163.com"
* "age":32
* }
* 2. Docker方式安装MongoDB 3.7.9版本(这个步骤,不必练习!!)
data:image/s3,"s3://crabby-images/c1161/c1161d3ad538ccc96d7920f730713ec6454f6dd2" alt="image"
* [https://hub.docker.com/_/mongo/](https://hub.docker.com/_/mongo/)# MongoDB Docker官网
* 按照提示,下拉想要的版本镜像
* Container shell access and viewing MongoDB logs
* $ docker exec -it some-mongo bash # 进入容器
* $ docker logs some-mongo # 查看容器启动日志
* 推荐启动Docker镜像方式
* (1) docker run -d --name some-mongo -v /home/jet/mongo_data_db:/data/db -p 27017:27017 -e MONGO_INITDB_ROOT_USERNAME=mongoadmin -e MONGO_INITDB_ROOT_PASSWORD=secret mongo:3.7.9
* (2) docker run -it --rm --link some-mongo:mongo mongo mongo --host mongo -u mongoadmin -p secret --authenticationDatabase admin some-db
data:image/s3,"s3://crabby-images/c405e/c405eae8a133abc55d244f2d48b5c105fb8cc6d1" alt="image"
* # 这是整了2个容器
data:image/s3,"s3://crabby-images/94e5d/94e5d44b467f4775ac34661340435a95d5c7e6f5" alt="image"
* 或者用1个容器,直接1个容器里启动
data:image/s3,"s3://crabby-images/a6110/a6110bcb55306ab29c23c18cedbdee2f7369b6e4" alt="image"
data:image/s3,"s3://crabby-images/a22dc/a22dcb9753a73d49e410bccdb27a9d1910152f1a" alt="image"
* 3\. Docker方式安装 MongoDB 3.2版本 ( 推荐安装这个版本)
* 运行如下命令,启动 MongoDB
* docker run --name some-mongo -v /home/jet/mongo_data_db/:/data/db -p 27017:27017 -d mongo:3.2
data:image/s3,"s3://crabby-images/7693b/7693b2b94303d4cda1f7e9de432d34f7041d00ce" alt="image"
* 创建个用户 root2 / 123456 # 以后就需要用认证才能连接
* db.createUser({user:'root2',pwd:'123456',roles:[{role:'root',db:'admin'}]})
* # role:'root'为最高权限,可以在admin数据库中任何操作
* 4. 可视化工具连接MongoDB
* MongoBooster # 下载地址: [https://nosqlbooster.com/downloads](https://nosqlbooster.com/downloads)
data:image/s3,"s3://crabby-images/192a3/192a3eac00d3abbbfaf69e0727274e8fe2342d92" alt="image"
* MongoBooster 连接 MongoDB3.2版本没问题,其他高版本不支持。
* 使用工具 NoSQLBooster 连接 MongoDB
* 3.1 无认证方式的连接
data:image/s3,"s3://crabby-images/1b99f/1b99f0a4d1c40eb48802a1043fb29606e480669b" alt="image"
data:image/s3,"s3://crabby-images/d5770/d5770f3c2cf0c96eb4c8f5abfbe5097653e4e2c2" alt="image"
* 3.2 有认证的连接
data:image/s3,"s3://crabby-images/2f554/2f554fd9a8311f0b32a97068277665a99723c276" alt="image"
* 5\. MongoDB 查询介绍
* 认证、查询所有用户
data:image/s3,"s3://crabby-images/0900d/0900d980968f07606f8d7490feb70ea0f5e47dd6" alt="image"
* show dbs:显示数据库列表
data:image/s3,"s3://crabby-images/db08f/db08fdf7a8cf0eb716f81e2383b671a528fa9fce" alt="image"
* show collections:显示当前数据库中的集合(类似关系数据库中的表)
data:image/s3,"s3://crabby-images/29602/2960228cc85aec2f508bb422cf1c695352c9de26" alt="image"
data:image/s3,"s3://crabby-images/44839/448398db49b5d8472ef6d5f155bc6c5fe14fd03e" alt="image"
data:image/s3,"s3://crabby-images/4908a/4908aea6d63f7dabc6080418409a357721c6cd0f" alt="image"
* # use admin:切换当前数据库至admin数据库,这和MySQL里面的意思一样
data:image/s3,"s3://crabby-images/940a9/940a90e9710df3b210be2b087acbcdb51a7b7596" alt="image"
* show users:显示用户
data:image/s3,"s3://crabby-images/16eb2/16eb235d3d621e62d0b2e02266dee0848c26fc96" alt="image"
* db.help() # 显示数据库操作命令
data:image/s3,"s3://crabby-images/95011/95011adbece993f43b45815ddc5cc3a7708fe37f" alt="image"
* Help查看命令提示
data:image/s3,"s3://crabby-images/e60f0/e60f00f5e6637f8fb89f280a5ec218849c8586c1" alt="image"
* help
* db.help();
* db.yourColl.help();
* db.youColl.find().help();
* rs.help();
* db.foo.help() # 显示集合操作命令,同样有很多的命令,foo指的是当前数据库下,一个叫foo的集合
data:image/s3,"s3://crabby-images/2ec61/2ec61b29b7204dabbcd9e95b5cfac1af171a8e40" alt="image"
* db.system.users.find():对于当前数据库中的 system.users 集合进行数据查找(由于没有条件,会列出所有数据)
data:image/s3,"s3://crabby-images/fc36f/fc36f4671cc54481672a6db0ada46fbbb787ee0f" alt="image"
* # select * from system.users;
* db.system.users.find( { user : 'root1' } ) # 对于当前数据库中的 system.users 集合进行查找,条件是数据中有一个属性叫user,且 user 的值为 'root1'
data:image/s3,"s3://crabby-images/e9bf4/e9bf489844a6284f538b553c7467b3df9d2172ad" alt="image"
* 等同于Mysql中: select * from system.users where user = 'root1' ;
* db.col2.find({title:'NoSQL Overview'},) 与 db.col2.find({title:'NoSQL Overview'}) 查询结果都一样
data:image/s3,"s3://crabby-images/0df2b/0df2b3c812cf1f00210c29a5a6f3e4e8bcf2eaa2" alt="image"
data:image/s3,"s3://crabby-images/d9b67/d9b67429cda64358987d0b71fd177095ca86c256" alt="image"
data:image/s3,"s3://crabby-images/c90af/c90af9ed4154a8c178ea74a126f6268d3a45a8f7" alt="image"
* 插入数据
data:image/s3,"s3://crabby-images/f7367/f7367d2de3de62cd70394616e1b5954c14841402" alt="image"
data:image/s3,"s3://crabby-images/e7a44/e7a448c448c31b866807c2b9a8e44904b3f098ac" alt="image"
data:image/s3,"s3://crabby-images/a5764/a5764e31307b6e54870e57a67b3b64477071be12" alt="image"
* // 插入数据时,name / 'name' / "name" 都是一样的
* insert VS save
data:image/s3,"s3://crabby-images/84861/8486115e2d581d0a4b71a7a538941f45cb98b97a" alt="image"
data:image/s3,"s3://crabby-images/4e47b/4e47bd8f5a821a07659fa230553caf428534703d" alt="image"
data:image/s3,"s3://crabby-images/1ca3c/1ca3ca911232fd94fd784c0a015501535fd9a490" alt="image"
data:image/s3,"s3://crabby-images/4997f/4997f6922181a8092da2a438ae5194d38190f617" alt="image"
* 集合中文档中的域可以多样化
data:image/s3,"s3://crabby-images/feba3/feba31c5d54d1219f9d2aefe83d103d23604b56b" alt="image"
* 查询去掉后的当前聚集集合中的某列的重复数据
data:image/s3,"s3://crabby-images/0837a/0837a1d5b1a52389840556cf0a77581cc9e1e674" alt="image"
data:image/s3,"s3://crabby-images/da6f6/da6f62b861db75e4dae2069dddced3e50fe3e17a" alt="image"
data:image/s3,"s3://crabby-images/48f2d/48f2de1f5898479cb8cd31eccfd4a4d8b73b472b" alt="image"
data:image/s3,"s3://crabby-images/537e2/537e2e4636fb5cefd0f216463cd341a36d649c87" alt="image"
data:image/s3,"s3://crabby-images/02be6/02be6f90fcd6b1f8faa2a3a5f8e9f1dc7b5bd4b5" alt="image"
* db.test.distinct("name");
* 会过滤掉name中的相同数据
* 相当于:select distict name from userInfo;
* 查询多个条件同时成立,等同于 SQL中 and
data:image/s3,"s3://crabby-images/6cf8d/6cf8d4353daa08245c6bba1c4aa764c7eec9da1b" alt="image"
data:image/s3,"s3://crabby-images/582d0/582d05bf13a7af4aaeb2ef9cae99797d8d12db60" alt="image"
* // SQL中: select * from test where name = 'Lucky' and sex = 'Female' ;
* 查询age > 22的记录
data:image/s3,"s3://crabby-images/ebba0/ebba0b5a224e3a861b99491bca88993dd3f916d1" alt="image"
data:image/s3,"s3://crabby-images/d2241/d2241d9d430da51b429919976d808852b2f34ebe" alt="image"
* db.test.find({age: {$gt: 22}});
* 相当于:select * from userInfo where age >22;
data:image/s3,"s3://crabby-images/a169a/a169aba3b82a6ba6210b2de0a633c425da4e53f2" alt="image"
data:image/s3,"s3://crabby-images/447f5/447f5296ac613df62a0f60099102655e6a327524" alt="image"
data:image/s3,"s3://crabby-images/e8310/e831053d5bf17bea88629622a490ed828db4145d" alt="image"
* db.test.find({age:{$lt:20}})
* 相当于:select * from test where age <20;
* db.test.find({age: {$lte: 18}});
data:image/s3,"s3://crabby-images/c2ceb/c2ceb1ff2dec228d88434c3f50c226ce19dc419f" alt="image"
* db.test.find({age: {$gte: 18}});
data:image/s3,"s3://crabby-images/e389d/e389d71c9ef4f26c3c856dc11f4cf39ac019f878" alt="image"
* 相当于:select * from test where age >= 25;
* 20 >=age>=18
data:image/s3,"s3://crabby-images/f277d/f277d03e558c64e546ee05a55d9ac33148872c5a" alt="image"
data:image/s3,"s3://crabby-images/fe5e6/fe5e6a2bcc548e9b7fab8ab8f2f7f5420d034d70" alt="image"
* db.test.find({age: {$gte: 18,$lte:20}});
* 等同于SQL: select * from test where age between 18 and 20 ;
* 不等于 $ne
data:image/s3,"s3://crabby-images/5d832/5d832eb8c605309773a14be96f71a3a3b8f653a5" alt="image"
data:image/s3,"s3://crabby-images/c6a94/c6a940c9cc8a50e7d4e3232143c9e9e3e810ac05" alt="image"
* 在某范围内 $in
data:image/s3,"s3://crabby-images/0ddba/0ddba3dece6303be5a14ab790af8b15a71115b50" alt="image"
data:image/s3,"s3://crabby-images/66a2a/66a2a92db8320ccdaa1d70265a033f540b27cba8" alt="image"
* 不在某范围内 $nin
* $mod 取模 // 查询所有 age % 10 == 3 的docs
data:image/s3,"s3://crabby-images/c1317/c13171df895e9c00d3b5225af00ab7495954c239" alt="image"
* 模糊查询 查询 name 中包含 rek 的数据 // db.test.find({name:/rek/})
data:image/s3,"s3://crabby-images/1f67f/1f67f710ea9392f2f1a8f378c90c7a17355f4687" alt="image"
* 查询name中以 Dere 开头的 // db.test.find({name:/^Der/})
data:image/s3,"s3://crabby-images/0c6ac/0c6ac9768ad9a919dabcfe34b1312d0864da14b2" alt="image"
data:image/s3,"s3://crabby-images/1fca3/1fca3a5389bae82a934dc10cff26480852125911" alt="image"
* 查询name中以 33 开头的 // db.test.find({name:/33$/})
data:image/s3,"s3://crabby-images/76715/76715d0d8635060ab0c945ae9bbd24fc2165f9f3" alt="image"
* 查询指定列name、age数据 // db.test.find({}, {name: 1, age: 1});
data:image/s3,"s3://crabby-images/25b3a/25b3a368408874e3c115bd5533c15edafd4c70fd" alt="image"
data:image/s3,"s3://crabby-images/06e70/06e70fc2f764ad894f3ab746321ae0443b8d7345" alt="image"
data:image/s3,"s3://crabby-images/3dd76/3dd76d098f2b006f9edd727c4a22b035027edc73" alt="image"
data:image/s3,"s3://crabby-images/a976f/a976fcf0fcd83c33f9b1ddf75c2f7c703079a888" alt="image"
data:image/s3,"s3://crabby-images/9d27d/9d27d3727c170e2ff8f8745b1969b8904d258a67" alt="image"
* 查询指定列name、age数据, age > 18 // db.test.find({age: {$gt: 18}}, {name: 1, age: 1});
data:image/s3,"s3://crabby-images/547de/547de6991ccb6e77fcf07fe555419529850f2872" alt="image"
* 排序(按照年龄排序)
data:image/s3,"s3://crabby-images/a71e0/a71e0c04304759121adffc4236c410d7f7dd7ecb" alt="image"
data:image/s3,"s3://crabby-images/7a050/7a0508ed688247f6c375972c54c0e97bcea576ca" alt="image"
data:image/s3,"s3://crabby-images/c2d49/c2d496866736c2ad908ba55fa72f280354d7f450" alt="image"
* 升序:db.test.find().sort({age: 1});
* 降序:db.test.find().sort({age: -1});
* 或
data:image/s3,"s3://crabby-images/6d573/6d573dfbdc278e94da526b7b81087775871100c3" alt="image"
data:image/s3,"s3://crabby-images/06285/0628510a13b5b6573060926a5b25ceb2514094a4" alt="image"
data:image/s3,"s3://crabby-images/f40b9/f40b961d1d7ae8f8ead0cbc7e717d435f8c8893e" alt="image"
* 统计 count()
data:image/s3,"s3://crabby-images/52c4a/52c4a5e0cadb4003492a93027a2f7d080eb1df02" alt="image"
* 查询前几条 // limit(n)
data:image/s3,"s3://crabby-images/5e2c8/5e2c8cdd08490064da251bc6fd0d56f68f1ab299" alt="image"
data:image/s3,"s3://crabby-images/56d85/56d85b2daff727aa3e30ecaa777f4c93a8f1dacf" alt="image"
data:image/s3,"s3://crabby-images/24780/24780660bb33b3e6f7105d5a9cede45eed0b08f3" alt="image"
data:image/s3,"s3://crabby-images/2f107/2f107d9d1f5362da6cebed1a299185cdb80bdee2" alt="image"
* 大量造数
data:image/s3,"s3://crabby-images/1edca/1edca9c3eb7afa131350b359a2ec33f9fa48146f" alt="image"
* 删除
data:image/s3,"s3://crabby-images/56d8a/56d8a448d719e71108bb2fc662e4c00e318e49e6" alt="image"
data:image/s3,"s3://crabby-images/8302e/8302e4cc6d1082be2fd0d7d3f025d105bf03130e" alt="image"
* 删除集合test2 // db.test2.drop()
* 删除当前数据库
data:image/s3,"s3://crabby-images/ed843/ed843312832cf03483126a9be6dce403c3d070da" alt="image"
data:image/s3,"s3://crabby-images/9b5ea/9b5ea5127a4b09fec48a5a7fbdb55dcf6e7fce6e" alt="image"
* 更新 // 不保留其它fields
data:image/s3,"s3://crabby-images/e9dae/e9dae79bfb810bcbfd7cfe5358e86bf1a203f4bf" alt="image"
data:image/s3,"s3://crabby-images/d72c4/d72c45dff3a0a1871fd3f36f5cec7fca61c063ae" alt="image"
* 更新 // 保留其它fields
data:image/s3,"s3://crabby-images/0dbd6/0dbd6acc6804dca370844a0bde609e58fe0b8f23" alt="image"
data:image/s3,"s3://crabby-images/2d49a/2d49a0851950915578f6adc46a0db7a7edbe0fc6" alt="image"
* 更新 ? 新增
data:image/s3,"s3://crabby-images/e6500/e6500f6cff4949b108a0dfd99bff36156f77ae8d" alt="image"
data:image/s3,"s3://crabby-images/836d6/836d6193b75faed5c854cdf84515ab8011975871" alt="image"
data:image/s3,"s3://crabby-images/236cd/236cdaa78b29de9b24fe83b7f4969d8688221e1f" alt="image"
data:image/s3,"s3://crabby-images/ef9b0/ef9b01a782f53add493885b71f1ec63d91634b89" alt="image"
* 清空集合
data:image/s3,"s3://crabby-images/f503d/f503d0b15c267e0ac8afb65a45c36c8cb2aedc3b" alt="image"
* 聚合
* 聚合(aggregate)主要用于处理数据(诸如统计平均值,求和等),并返回计算后的数据结果。
* 例子
* 一次性插入3条数据
* var d;
* d=[{
* title: 'MongoDB Overview',
* description: 'MongoDB is no sql database',
* by_user: 'runoob.com',
* url: 'http://www.runoob.com',
* tags: ['mongodb', 'database', 'NoSQL'],
* likes: 100
* },
* {
* title: 'NoSQL Overview',
* description: 'No sql database is very fast',
* by_user: 'runoob.com',
* url: 'http://www.runoob.com',
* tags: ['mongodb', 'database', 'NoSQL'],
* likes: 10
* },
* {
* title: 'Neo4j Overview',
* description: 'Neo4j is no sql database',
* by_user: 'Neo4j',
* url: 'http://www.neo4j.com',
* tags: ['neo4j', 'database', 'NoSQL'],
* likes: 750
* }];
* db.col2.insert(d);
data:image/s3,"s3://crabby-images/71556/715565201c9c4ac577955ef6a47c373f073bf050" alt="image"
data:image/s3,"s3://crabby-images/cf7ea/cf7ea5a0929d21d393333d72790aa88ca5cb31df" alt="image"
* db.col2.aggregate().group({_id:"$by_user",count:{$sum:1}}) //根据by_user分组,统计个数
data:image/s3,"s3://crabby-images/fe96a/fe96a375881c031c40e522fe2f752e0951a87f1d" alt="image"
* > db.col2.aggregate().group({_id:"$by_user",count:{$sum:"$likes"}}) //以by_user分组,求和likes的值
data:image/s3,"s3://crabby-images/3db20/3db20a068c3fc07a320fa3c87e411a7fedcdcc48" alt="image"
* > db.col2.aggregate().group({_id:null,count:{$sum:"$likes"}}) //不分组,只根据likes字段求和
data:image/s3,"s3://crabby-images/43050/4305027141130bc166e77ab32fb16ae7bbbf26a8" alt="image"
* 表达式 描述 实例
* $sum 计算总和。 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$sum : "$likes"}}}])
* $avg 计算平均值 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$avg : "$likes"}}}])
* $min 获取集合中所有文档对应值得最小值。 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$min : "$likes"}}}])
* $max 获取集合中所有文档对应值得最大值。 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$max : "$likes"}}}])
* MongoBooster 常用快捷方式
* 选中 - F6 / 或者点击到哪一行,按F6,执行的是最后一行的语句
* Ctrl +T //打开shell
* Ctrl + R //刷新
* Ctrl + D // 复制当前行到下一行
网友评论