日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

NoSQL(3)

發(fā)布時間:2025/3/8 数据库 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 NoSQL(3) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

1、什么是MongoDB ?

MongoDB 是由C++語言編寫的,是一個基于分布式文件存儲的開源數(shù)據(jù)庫系統(tǒng)。

在高負載的情況下,添加更多的節(jié)點,可以保證服務器性能。

MongoDB 旨在為WEB應用提供可擴展的高性能數(shù)據(jù)存儲解決方案。

MongoDB 將數(shù)據(jù)存儲為一個文檔,數(shù)據(jù)結(jié)構(gòu)由鍵值(key=>value)對組成。

MongoDB 文檔類似于 JSON 對象。字段值可以包含其他文檔,數(shù)組及文檔數(shù)組。

2、MongoDB特性

MongoDB是一個可擴展、高性能的下一代數(shù)據(jù)庫,它的特點是高性能、易部署、易使用、存儲數(shù) 據(jù)方便,主要特性有:

? 面向文檔存儲,json格式的文檔易讀、高效;

? 模式自由,支持動態(tài)查詢、完全索引,無模式;

? 高效的數(shù)據(jù)存儲,效率提高;

? 支持復制和故障恢復;

? 以支持云級別的伸縮性,支持水平數(shù)據(jù)庫集群,可動態(tài)添加額外服務器;

3、MongoDB的工作方式

傳統(tǒng)的關(guān)系型數(shù)據(jù)庫一般有數(shù)據(jù)庫(database)、表(table)、記錄(record)三級層次構(gòu)成。

MongoDB同樣是由數(shù)據(jù)庫(database)、集合(collection)、文檔對象(documen)三個層次組 成。

文檔 類似于json的鍵值對。{"name":"tom","age":23} 集合 一組文檔的集合。

4、MongoDB局限與不足

32位系統(tǒng)上,不支持大于2.5G的數(shù)據(jù)。

單個文檔大小限制為16M。

鎖粒度太粗,MongoDB使用一把全局讀寫鎖。

不支持join操作和事務機制 對內(nèi)存要求比較大,至少要保證熱數(shù)據(jù)(索引,數(shù)據(jù)及系統(tǒng)其他開銷)都能裝進內(nèi)存

用戶權(quán)限方面較弱 MapReduce在單個實例上無法運行,可用Auto-Sharding實現(xiàn),是由JS引擎限制造成。

MapReduce的結(jié)果無法寫入到一個被Sharding的collection中,待后續(xù)版本解決

對于數(shù)組型的數(shù)據(jù)操作不夠豐富

?

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

重點關(guān)注: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/

創(chuàng)建數(shù)據(jù)目錄:

啟動:

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

以系統(tǒng)服務方式啟動:(服務腳本沒有成功,有待修正)

創(chuàng)建配置文件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?

?

按配置文件設(shè)置創(chuàng)建日志和數(shù)據(jù)文件存放目錄:

[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、基本操作作業(yè)?

1)創(chuàng)建一個數(shù)據(jù)庫 名字grade?

use grade


2)數(shù)據(jù)庫中創(chuàng)建一個集合名字 class?

db.createCollection('class')

3)集合中插入若干數(shù)據(jù) 文檔格式如下 {name:'zhang',age;10,sex:'m',hobby:['a','b','c']} hobby: draw sing dance basketball football pingpong computer?


自行插入數(shù)據(jù),后面查詢使用?
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']}})


統(tǒng)計愛好有三項的學生人數(shù)?

?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)增加、更新、刪除、統(tǒng)計?
將小紅的年齡變?yōu)?歲 興趣愛好變?yōu)?跳舞 畫畫?
追加小明興趣愛好 唱歌?
小王興趣愛好增加 吹牛 打籃球?
小李增加愛好,跑步和唱歌,但是不要和以前的重復?
該班所有同學年齡加1?
刪除小明的sex屬性?
刪除小李興趣中的第一項?
將小紅興趣中的畫畫愛好刪除?
增加分數(shù)域 score:{'chinese':88,'english':78,'math':98}?
1. 按照性別分組統(tǒng)計每組人數(shù)?
2. 按照姓名分組,過濾出有重名的同學?
3. 統(tǒng)計每名男生的語文成績?
4. 將女生按照英語分數(shù)降序排列

未完待續(xù)

創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎勵來咯,堅持創(chuàng)作打卡瓜分現(xiàn)金大獎

總結(jié)

以上是生活随笔為你收集整理的NoSQL(3)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。