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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

clickhouse中bitmap在用户标签,访客去重生产中使用及clickhouse建表null值数据类型处理

發布時間:2024/3/13 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 clickhouse中bitmap在用户标签,访客去重生产中使用及clickhouse建表null值数据类型处理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

? ? ? ?

????????clickhouse中bitmap的使用對于用戶標簽及用戶,訪客跨維度去重統計是十分合適的選擇,具有更快的查詢效率。

1.bitmap

bitmap建表方式:

create table test.bitmap_test(tenant_id String comment '租戶id',shop_id String comment '門店id',h int comment '小時段',uv AggregateFunction(groupBitmap(),Int64) comment '記錄訪客人數',dt Date comment '日期' )engine =AggregatingMergeTree() partition by (dt) order by (tenant_id,shop_id) settings index_granularity =8192;

uv字段就是bitmap的數據類型,里面存儲的元素就是bitmap對象

創建數據源表:

create table test.bitmap_source(tenant_id String comment '租戶id',shop_id String comment '門店id',h int comment '小時段',uv String comment '記錄訪客人數',dt Date comment '日期' )engine =MergeTree() partition by (dt) order by (tenant_id,shop_id) settings index_granularity =8192;

將數據源表中的數據寫入bitmap表中:

insert into test.bitmap_testselecttenant_id,shop_id,h,groupBitmapState(metroHash64(uv)),dtfrom test.bitmap_test1group by tenant_id, shop_id, h, dt;

? ? ? ? 其中在將數據寫入bitmap表中,使用兩個函數metroHash64()將uv String類型的轉換為int類型,而后在使用groupBitmapState()函數轉換為bitmap對象存入bitmap表中。

? ? ? ? 通常在bitmap函數后加State則構造為bitmap對象數據,對于構造bitmap有兩種方式:

一種是從聚合函數groupBitmapState構造的,另外一種就是使用Array對象進行構建 //構建bitmap函數 SELECT bitmapOrCardinality(bitmapBuild([1,2,3,4,5,6]), bitmapBuild([3,4,5,6,7,8]));

求取去重的uv訪客量:

select groupBitmapOr(uv) from test.bitmap_test;

groupBitmap函數就是bitmap對象的聚合函數,作用就是去重統計該bitmap字段對象的的數量。

更多的bitmap聚合函數可以通過下面鏈接在官網中查看。

2.常用的位圖函數

? ? ? ? 除了上面所說到的聚合函數外,還用很多常用的位圖操作函數,對于位圖操作函數,可以在下面參考文章和官網資料中有詳細的介紹就不在一一解釋了。

3.bitmap表join求取去重效果

select * from (select * from test.bitmap_test t1 left join (select * from test.bitmap_test where tenant_id='1000000007') t2 on t1.tenant_id=t2.tenant_id);

?執行結果:

?對于t2中沒有關聯上的數據,uv直接為空,在使用bitmap聚合函數求取uv的去重人數時候,

select groupBitmapOr(t2.uv) from (select * from test.bitmap_test t1 left join (select * from test.bitmap_test where tenant_id='1000000007') t2 on t1.tenant_id=t2.tenant_id);

執行結果為:

該結果和下面語句的執行結果相同

select groupBitmapOr(uv) from test.bitmap_test where tenant_id='1000000007';

? ? ? ? ?這表示用bitmap聚合函數求取去重人數的時候字段中有空值并不會造成結果的不準確。

4.clickhouse建表時候null值字段設置

?建表時如果沒有對字段指定可以存儲null值,則在數據時候會對null值數據數值類型補為:0,字符串類型補為:''空字符串;

create table if not exists test(id int,name String ) engine =MergeTree() order by (id);--沒有對字段設置為可支持null值存儲,則保存時候會無法存入null值,對null數據替換

解決方案:clickhouse支持null值存儲語法

create table if not exists test(id Nullable(int),name Nullable(String) ) engine =MergeTree() order by (id);--使用nullable語法來實現支持null值

官網資料:

1.bitmap建表數據類型指定?

2.bitmap的聚合函數

3.位圖操作函數

參考文章:

1.BitMap使用在clickhouse中

2.參考

總結

以上是生活随笔為你收集整理的clickhouse中bitmap在用户标签,访客去重生产中使用及clickhouse建表null值数据类型处理的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 久久综合婷婷 | 日本50路肥熟bbw | 亚洲欧洲一区二区在线观看 | 婷婷色综合 | 国产乱妇无码大片在线观看 | 人人草在线视频 | 99精品视频在线观看 | 夜夜躁日日躁狠狠久久av | 欧美一区二区人人喊爽 | 可以直接看的无码av | 俺也去五月婷婷 | 免费一级毛片麻豆精品 | 欧美wwwwww | 亲切的金子餐桌片段的金子 | 香蕉视频黄污 | 宿舍女女闺蜜调教羞辱 | 美日韩精品一区二区 | 国产亚洲精品久久久久丝瓜 | 国产寡妇亲子伦一区二区三区四区 | 中文字幕一区二区av | 一级一级黄色片 | 亚洲国产成人精品女人久久久 | 国产毛片在线看 | 免费毛毛片 | 黄色一级免费视频 | 成人看片黄a免费看视频 | 国产一级二级毛片 | av免费片| 大地资源二中文在线影视免费观看 | 色播五月激情五月 | 国产美女一区二区三区 | 国产精品久久久久久久久免费 | 男人午夜天堂 | 国产真实乱人偷精品人妻 | av五月天在线 | 在线观看亚洲专区 | 都市乱淫| 实拍澡堂美女洗澡av | 91网在线| 中文在线观看视频 | 午夜男人天堂 | 亚洲欧洲精品一区二区三区 | 激情福利在线 | aa免费视频| 亚洲字幕在线观看 | av大片在线看 | 国产在线操 | 草莓视频在线观看18 | 成人国产精品 | 免费在线观看中文字幕 | 二区在线观看 | 国产成人精品在线 | 中文字幕在线观看不卡 | 午夜激情网 | 毛片88| 国产乱在线 | 日韩婷婷 | 中文字幕免费视频 | 久草网在线观看 | 欧美视频一区二区三区在线观看 | 免费成年人视频在线观看 | 狠狠干老司机 | 99久久毛片 | 欧洲av一区二区三区 | 黄色网址国产 | 97成人资源 | 精品熟女一区 | 日韩性欧美 | 关之琳三级全黄做爰在线观看 | 成人软件在线观看 | 在线观看的黄网 | 免费成人av在线 | 粉嫩av网 | 可以直接看av的网址 | 欧美一区成人 | 高清亚洲 | 日本黄色网页 | 人人草人人干 | 亚洲国产成人精品一区二区三区 | 亚洲精品乱码久久久久久蜜桃动漫 | 久久伊人精品视频 | 最全aⅴ番号库网 | 欧美高清在线视频 | 无码国产精品一区二区免费16 | 亚洲射射射 | 3d动漫精品啪啪一区二区下载 | 久久99网 | 国产精品嫩草69影院 | 少妇在线播放 | 亚洲一区二区福利 | 成熟人妻av无码专区 | 懂色av一区二区三区在线播放 | 麻豆自拍视频 | 毛片在线视频观看 | 午夜性生活片 | 国产在线观看免费高清 | 麻豆av在线| 97人妻精品一区二区免费 | 看黄色一级视频 |