欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

對(duì)標(biāo)mongodb存儲(chǔ)類(lèi)JSON數(shù)據(jù)文檔統(tǒng)計(jì)分析詳解

 更新時(shí)間:2022年06月15日 09:57:47   作者:字母哥博客  
這篇文章主要介紹了對(duì)標(biāo)mongodb存儲(chǔ)類(lèi)JSON數(shù)據(jù)文檔統(tǒng)計(jì)分析,只是介紹了簡(jiǎn)單的查詢,其實(shí)針對(duì)各種統(tǒng)計(jì)分析場(chǎng)景,clickhouse提供了超級(jí)多的統(tǒng)計(jì)分析函數(shù)、窗口函數(shù)等等,當(dāng)然針對(duì)數(shù)組的數(shù)據(jù)類(lèi)型也有很多的統(tǒng)計(jì)分析函數(shù),需要的朋友可以參考下

一、文檔存儲(chǔ)的需求

很多的開(kāi)發(fā)者都使用過(guò)mongodb,在mongodb中數(shù)據(jù)記錄是以文檔的形式存在的(類(lèi)似于一種多級(jí)嵌套SQL的形式)。比如下面的JSON數(shù)據(jù)結(jié)構(gòu):dev_ip表示某一臺(tái)服務(wù)器的ip、location字段存放經(jīng)緯度、meminfo.total和meminfo.userd分別代表內(nèi)存總量和使用量。

[{
  "dev_ip": "123.46.5.111",
  "location": [39.916527, 116.397128],
  "meminfo": {
    "total": 64,
    "used": 23.2
  }
},
{
  "dev_ip": "123.46.5.112",
  "location": [39.916144, 116.392582],
  "meminfo": {
    "total": 64,
    "used": 27.8
  }
}]

二、建表

存儲(chǔ)文檔需要使用到Map這種數(shù)據(jù)類(lèi)型,在某些比較舊的版本中,Map數(shù)據(jù)類(lèi)型還是實(shí)驗(yàn)性的,不能直接使用。如果想使用,需要執(zhí)行set allow_experimental_map_type = 1;。
然后我們可以按照J(rèn)SON的數(shù)據(jù)結(jié)構(gòu)來(lái)建表,location是數(shù)組Array數(shù)據(jù)類(lèi)型,meminfo是Map數(shù)據(jù)類(lèi)型。

CREATE TABLE dev_meminfo (
  dev_ip String,  
  location Array(Float64),
  meminfo Map(String, Float32)
)
ENGINE = MergeTree()
ORDER BY dev_ip;

clickhouse提供了數(shù)組類(lèi)型Array(T),數(shù)組類(lèi)型由多個(gè)T元素組成。T可以是任意的基礎(chǔ)數(shù)據(jù)類(lèi)型,或者也可以是數(shù)組類(lèi)型。如果是數(shù)組類(lèi)型就形成了多維數(shù)組,Cickhouse對(duì)多維數(shù)組的支持有限,所以不建議使用多維數(shù)組。數(shù)組里面所有的T元素的數(shù)據(jù)類(lèi)型必須是一樣的,否則會(huì)拋出異常。

三、數(shù)據(jù)入庫(kù)

在linux環(huán)境下,我們可以將JSON數(shù)據(jù)保存為一個(gè)文檔,命名如:dev_meminfo.json。然后使用下面的命令行,完成文檔JSON數(shù)據(jù)的入庫(kù)。jq的作用是將JSON數(shù)組及Map從結(jié)構(gòu)中剝離出來(lái),從而符合JSONEachRow要求的輸入格式。

cat dev_meminfo.json |jq -c .[] | clickhouse-client --database acaidb -m -u acai --password '<你的密碼>'  \
--query="INSERT INTO dev_meminfo FORMAT JSONEachRow"

或者我們可以直接使用INSERT語(yǔ)句來(lái)完成數(shù)據(jù)的單條插入,如下:

INSERT  INTO dev_meminfo FORMAT JSONEachRow {"dev_ip": "123.46.5.112", "location": [39.916144, 116.392582],"meminfo": {"total": 64,"used": 27.8}};

四、查詢數(shù)據(jù)

select * 的方式查詢數(shù)據(jù):

#  clickhouse-client --database acaidb -m -u acai --password '4rfv$RFV'  --query="SELECT * FROM dev_meminfo"
123.46.5.111    [39.916527,116.397128]  {'total':64,'used':23.2}
123.46.5.112    [39.916144,116.392582]  {'total':64,'used':27.8}

使用字段名稱方式查詢數(shù)據(jù),需要注意的是Ciickhouse的數(shù)組的下標(biāo)是從0開(kāi)始的,這與我們傳統(tǒng)編程開(kāi)發(fā)中的規(guī)范是不一致的。

# clickhouse-client --database acaidb -m -u acai --password '4rfv$RFV'  --query="SELECT dev_ip,location[1],location[2],meminfo['total'],meminfo['used'] FROM dev_meminfo"
123.46.5.111    39.916527       116.397128      64      23.2
123.46.5.112    39.916144       116.392582      64      27.8

五、總結(jié)

我們看到clickhouse可以代替mongodb進(jìn)行類(lèi)JSON文檔數(shù)據(jù)的存儲(chǔ),而且支持SQL查詢統(tǒng)計(jì)分析,這一點(diǎn)是比較吸引人的。我只是介紹了簡(jiǎn)單的查詢,其實(shí)針對(duì)各種統(tǒng)計(jì)分析場(chǎng)景,clickhouse提供了超級(jí)多的統(tǒng)計(jì)分析函數(shù)、窗口函數(shù)等等,當(dāng)然針對(duì)數(shù)組的數(shù)據(jù)類(lèi)型也有很多的統(tǒng)計(jì)分析函數(shù)。
更為值得注意的是:筆者看到一些測(cè)評(píng)文章,clickhouse的的統(tǒng)計(jì)分析性能是mongodb的近百倍之多(筆者自己尚未驗(yàn)證,請(qǐng)關(guān)注我的專欄后續(xù)文章)。但是也不是說(shuō)clickhouse可以代替mongodb的所有應(yīng)用場(chǎng)景,至少面向用戶的并發(fā)請(qǐng)求的場(chǎng)景clickhouse是不滿足的,因?yàn)閏lickhouse的定位是數(shù)據(jù)倉(cāng)庫(kù),主要是面向數(shù)據(jù)分析OLAP場(chǎng)景,而不是面向用戶高并發(fā)的聯(lián)機(jī)事務(wù)處理OLTP。

到此這篇關(guān)于對(duì)標(biāo)mongodb存儲(chǔ)類(lèi)JSON數(shù)據(jù)文檔統(tǒng)計(jì)分析的文章就介紹到這了,更多相關(guān)mongodb存儲(chǔ)類(lèi)JSON數(shù)據(jù)文檔統(tǒng)計(jì)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MongoDB 入門(mén)指南

    MongoDB 入門(mén)指南

    這篇文章主要介紹了MongoDB 入門(mén)指南的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • centos離線安裝mongodb-database-tools方法詳解

    centos離線安裝mongodb-database-tools方法詳解

    這篇文章主要介紹了centos離線安裝mongodb-database-tools方法詳解的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • mongodb實(shí)現(xiàn)數(shù)組對(duì)象求和方法實(shí)例

    mongodb實(shí)現(xiàn)數(shù)組對(duì)象求和方法實(shí)例

    這篇文章主要給大家介紹了關(guān)于mongodb實(shí)現(xiàn)數(shù)組對(duì)象求和的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-01-01
  • MongoDB中的常用操作$push、$pushAll和$pull示例詳解

    MongoDB中的常用操作$push、$pushAll和$pull示例詳解

    MongoDB從2.2版本開(kāi)始支持$push操作符,$push是用于在數(shù)組中添加一個(gè)元素的更新操作符,它將指定的值追加到數(shù)組的末尾,本文給大家介紹MongoDB的常用操作$push、$pushAll和$pull,感興趣的朋友一起看看吧
    2023-12-12
  • MongoDB數(shù)據(jù)庫(kù)安裝配置、基本操作實(shí)例詳解

    MongoDB數(shù)據(jù)庫(kù)安裝配置、基本操作實(shí)例詳解

    這篇文章主要介紹了MongoDB數(shù)據(jù)庫(kù)安裝配置、基本操作,結(jié)合實(shí)例形式詳細(xì)分析了MongoDB數(shù)據(jù)庫(kù)安裝配置具體步驟、相關(guān)命令與基本操作實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2020-01-01
  • springboot整合mongodb?changestream的示例代碼

    springboot整合mongodb?changestream的示例代碼

    Chang?Stream(變更記錄流)?是指collection(數(shù)據(jù)庫(kù)集合)的變更事件流,應(yīng)用程序通過(guò)db.collection.watch()這樣的命令可以獲得被監(jiān)聽(tīng)對(duì)象的實(shí)時(shí)變更,本文給大家介紹springboot整合mongodb?changestream的示例代碼,感興趣的朋友一起看看吧
    2022-02-02
  • Mongodb數(shù)據(jù)庫(kù)誤刪后的恢復(fù)方法(兩種)

    Mongodb數(shù)據(jù)庫(kù)誤刪后的恢復(fù)方法(兩種)

    本文給大家分享兩種方法來(lái)實(shí)現(xiàn)Mongodb數(shù)據(jù)庫(kù)誤刪后的恢復(fù),每種方法給大家介紹的都非常詳細(xì),需要的朋友參考下吧
    2018-08-08
  • 使用Mongodb實(shí)現(xiàn)打卡簽到系統(tǒng)的實(shí)例代碼

    使用Mongodb實(shí)現(xiàn)打卡簽到系統(tǒng)的實(shí)例代碼

    這篇文章主要介紹了使用Mongodb實(shí)現(xiàn)打卡簽到系統(tǒng)的示例代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-05-05
  • MongoDB 用戶管理

    MongoDB 用戶管理

    這篇文章主要介紹了MongoDB 如何對(duì)用戶管理,幫助大家更好的理解和使用MongoDB數(shù)據(jù)庫(kù),感興趣的朋友可以了解下
    2020-09-09
  • MongoDB常用命令小結(jié)

    MongoDB常用命令小結(jié)

    這篇文章主要介紹了MongoDB的一些常用命令,學(xué)習(xí)與使用MongoDB數(shù)據(jù)庫(kù)的朋友可以參考下
    2013-08-08

最新評(píng)論