1、什么是MongoDB ?
MongoDB 是由C++語言編寫的,是一個基于分布式文件存儲的開源數據庫系統。
在高負載的情況下,添加更多的節點,可以保證服務器性能。
MongoDB 旨在為WEB應用提供可擴展的高性能數據存儲解決方案。
MongoDB 將數據存儲為一個文檔,數據結構由鍵值(key=>value)對組成。
MongoDB 文檔類似于 JSON 對象。字段值可以包含其他文檔,數組及文檔數組。
2、MongoDB特性
MongoDB是一個可擴展、高性能的下一代數據庫,它的特點是高性能、易部署、易使用、存儲數 據方便,主要特性有:
? 面向文檔存儲,json格式的文檔易讀、高效;
? 模式自由,支持動態查詢、完全索引,無模式;
? 高效的數據存儲,效率提高;
? 支持復制和故障恢復;
? 以支持云級別的伸縮性,支持水平數據庫集群,可動態添加額外服務器;
3、MongoDB的工作方式
傳統的關系型數據庫一般有數據庫(database)、表(table)、記錄(record)三級層次構成。
MongoDB同樣是由數據庫(database)、集合(collection)、文檔對象(documen)三個層次組 成。
文檔 類似于json的鍵值對。{"name":"tom","age":23} 集合 一組文檔的集合。
4、MongoDB局限與不足
32位系統上,不支持大于2.5G的數據。
單個文檔大小限制為16M。
鎖粒度太粗,MongoDB使用一把全局讀寫鎖。
不支持join操作和事務機制 對內存要求比較大,至少要保證熱數據(索引,數據及系統其他開銷)都能裝進內存
用戶權限方面較弱 MapReduce在單個實例上無法運行,可用Auto-Sharding實現,是由JS引擎限制造成。
MapReduce的結果無法寫入到一個被Sharding的collection中,待后續版本解決
對于數組型的數據操作不夠豐富
?
1、使用yum在線安裝MongoDB?
配置yum源
[mongodb-enterprise]
name=MongoDB Enterprise Repository
baseurl=https://repo.mongodb.com/yum/redhat/$releasever/mongodb-enterprise/4.2/$basearch/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-4.2.asc
[root@localhost yum.repos.d]# yum list | grep -i mongodb
重點關注:libmysqlclient.so.18()(64bit)
解決:
缺少Percona-XtraDB-Cluster-shared-55-5.5.37-25.10.756.el6.x86_64.rpm這個包
# wget http://www.percona.com/redir/downloads/Percona-XtraDB-Cluster/5.5.37-25.10/RPM/rhel6/x86_64/Percona-XtraDB-Cluster-shared-55-5.5.37-25.10.756.el6.x86_64.rpm
# rpm -ivh Percona-XtraDB-Cluster-shared-55-5.5.37-25.10.756.el6.x86_64.rpm?
我們下載完后,啟動服務就行了。這也太慢了
?
2、源碼安裝MongoDB并配置服務腳本?
下載軟件包:
鏈接:https://pan.baidu.com/s/1GfDaKYbaKBK5xHln8qspMg?
提取碼:yang?
解壓:
tar xf mongodb-linux-x86_64-rhel70-3.4.7.tgz ?-C /usr/local/
創建數據目錄:
啟動:
echo "export PATH=$PATH:/usr/local/mongodb/bin" > /etc/profile.d/mongo.sh
source /etc/profile.d/mongo.sh
mongod --dbpath /data/db/ &
?ps -ef | grep mongod
netstat -lnupt | grep 27017
lsof -i tcp:27017
以系統服務方式啟動:(服務腳本沒有成功,有待修正)
創建配置文件mongod.conf
vim /usr/local/mongodb/bin/mongod.conf
systemLog:
destination: file?
path: /usr/local/mongodb/log/mongodb.log?
logAppend: true
storage:
dbPath: /usr/local/mongodb/data?
processManagement:
fork: true?
?
按配置文件設置創建日志和數據文件存放目錄:
[root@localhost ~]# mkdir -p /usr/local/mongodb/{data,log}
配置mongodb.service文件
vim /usr/lib/systemd/system/mongodb.service
[Unit]
Description=mongodb service daemon
After=network.target
[Service]
Type=forking
ExecStart=/usr/local/mongodb/bin/mongod -f ?/usr/local/mongodb/bin/mongod.conf
ExecStop=/usr/local/mongodb/bin/mongod --shutdown -f ?/usr/local/mongodb/bin/mongod.conf
PrivateTmp=true
[Install]
WantedBy=multi-user.target
?
保存mongodb.service文件后,需要輸入命令進行重新加載.
3、基本操作作業?
1)創建一個數據庫 名字grade?
use grade
2)數據庫中創建一個集合名字 class?
db.createCollection('class')
3)集合中插入若干數據 文檔格式如下 {name:'zhang',age;10,sex:'m',hobby:['a','b','c']} hobby: draw sing dance basketball football pingpong computer?
自行插入數據,后面查詢使用?
4)查詢操作?
查看班級所有人信息?
db.class.find()
查看班級中年齡為8歲的學生信息?
db.class.find({age:8})
查看年齡大于10歲的學生信息?
db.class.find({age:{$gt:10}})
查看年齡在 4---8歲之間的學生信息?
db.class.find({age:{$gt:4,$lt:8}})
找到年齡為6歲且為男生的學生?
db.class.find({age:6,sex:'m'})
找到年齡小于7歲或者大于10歲的學生?
db.class.find({$or:[{age:{$gt:10}},{age:{$lt:7}}]})
找到年齡是8歲或者11歲的學生?
db.class.find({age:{$in:[8,11]}})
找到興趣愛好有兩項的學生?
db.class.find({hobby:{$size:2}})
找到興趣愛好有draw的學生?
db.class.find({hobby:"draw"})
找到既喜歡畫畫又喜歡跳舞的學生?
db.class.find({hobby:{$all:['draw','dance']}})
統計愛好有三項的學生人數?
?db.class.find({hobby:{$size:3}}).count()
找出本班年齡第二大的學生?
db.class.find({}).sort({age:-1}).skip(1).limit(1)
查看學生的興趣范圍?
db.class.distinct('hobby')
將學生按年齡排序找到年齡最大的三個?
db.class.find({}).sort({age:-1}).limit(3)
刪除所有 年級大于12或者小于4歲的學生
db.class.remove({$or:[{age:{$lt:6}},{age:{$gt:12}}]})
?
5)增加、更新、刪除、統計?
將小紅的年齡變為8歲 興趣愛好變為 跳舞 畫畫?
追加小明興趣愛好 唱歌?
小王興趣愛好增加 吹牛 打籃球?
小李增加愛好,跑步和唱歌,但是不要和以前的重復?
該班所有同學年齡加1?
刪除小明的sex屬性?
刪除小李興趣中的第一項?
將小紅興趣中的畫畫愛好刪除?
增加分數域 score:{'chinese':88,'english':78,'math':98}?
1. 按照性別分組統計每組人數?
2. 按照姓名分組,過濾出有重名的同學?
3. 統計每名男生的語文成績?
4. 將女生按照英語分數降序排列
未完待續