<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
很多的開發者都使用過mongodb,在mongodb中資料記錄是以檔案的形式存在的(類似於一種多級巢狀SQL的形式)。比如下面的JSON資料結構:dev_ip表示某一臺伺服器的ip、location欄位存放經緯度、meminfo.total和meminfo.userd分別代表記憶體總量和使用量。
[{ "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 } }]
儲存檔案需要使用到Map這種資料型別,在某些比較舊的版本中,Map資料型別還是實驗性的,不能直接使用。如果想使用,需要執行set allow_experimental_map_type = 1;
。
然後我們可以按照JSON的資料結構來建表,location是陣列Array資料型別,meminfo是Map資料型別。
CREATE TABLE dev_meminfo ( dev_ip String, location Array(Float64), meminfo Map(String, Float32) ) ENGINE = MergeTree() ORDER BY dev_ip;
clickhouse提供了陣列型別Array(T),陣列型別由多個T元素組成。T可以是任意的基礎資料型別,或者也可以是陣列型別。如果是陣列型別就形成了多維陣列,Cickhouse對多維陣列的支援有限,所以不建議使用多維陣列。陣列裡面所有的T元素的資料型別必須是一樣的,否則會丟擲異常。
在linux環境下,我們可以將JSON資料儲存為一個檔案,命名如:dev_meminfo.json。然後使用下面的命令列,完成檔案JSON資料的入庫。jq
的作用是將JSON陣列及Map從結構中剝離出來,從而符合JSONEachRow要求的輸入格式。
cat dev_meminfo.json |jq -c .[] | clickhouse-client --database acaidb -m -u acai --password '<你的密碼>' --query="INSERT INTO dev_meminfo FORMAT JSONEachRow"
或者我們可以直接使用INSERT語句來完成資料的單條插入,如下:
INSERT INTO dev_meminfo FORMAT JSONEachRow {"dev_ip": "123.46.5.112", "location": [39.916144, 116.392582],"meminfo": {"total": 64,"used": 27.8}};
select *
的方式查詢資料:
# 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}
使用欄位名稱方式查詢資料,需要注意的是Ciickhouse的陣列的下標是從0開始的,這與我們傳統程式設計開發中的規範是不一致的。
# 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
我們看到clickhouse可以代替mongodb進行類JSON檔案資料的儲存,而且支援SQL查詢統計分析,這一點是比較吸引人的。我只是介紹了簡單的查詢,其實針對各種統計分析場景,clickhouse提供了超級多的統計分析函數、視窗函數等等,當然針對陣列的資料型別也有很多的統計分析函數。
更為值得注意的是:筆者看到一些測評文章,clickhouse的的統計分析效能是mongodb的近百倍之多(筆者自己尚未驗證,請關注我的專欄後續文章)。但是也不是說clickhouse可以代替mongodb的所有應用場景,至少面向使用者的並行請求的場景clickhouse是不滿足的,因為clickhouse的定位是資料倉儲,主要是面向資料分析OLAP場景,而不是面向使用者高並行的聯機事務處理OLTP。
到此這篇關於對標mongodb儲存類JSON資料檔案統計分析的文章就介紹到這了,更多相關mongodb儲存類JSON資料檔案統計內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45