日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

MySQL 如何設計統計數據表

瀏覽:72日期:2023-10-01 18:37:02
目錄是否需要實時更新物化視圖工具(Flexviews)計數表總結

緩存型數據表通常在統計數據時會經常用到,因此也會叫統計性數據。舉個例子來說,對于員工、部門數據表而言,我們可能會需要查詢一個部門下有多少員工。這時候有三種方式實現:

在部門下增加一個員工數量的字段,每次對員工進行增、改、刪操作時都需要同步更新員工數量(如果員工換部門,則需要更新多個部門的員工數量)。這種方式能夠保證實時性,但是卻很低效。對于如果是操作不頻繁時是沒問題的,假設相當頻繁,就意味著每次都需要操作兩張表,而且業務代碼都需要做埋點處理,將統計業務和普通業務深度耦合在一起了。 每次查詢的時候,從員工表中執行 SUM 函數,獲取該部門的員工數。這種方式避免了埋點,但是每次都需要去員工數據表求和,如果員工數據量大的話會很低效。 新建一張統計表,每隔一定時間從員工表中匯總每個部門的人員數量。這種定時抽取數據的方式會犧牲一定的實時性,但降低了代碼的耦合,由于部門不會太多,這張表的大小是可預測的,也提高了數據訪問的效率。這種方式即緩存型數據表。

以掘金的手機端個人中心為例,為展示每個用戶的關注人數、關注者和掘力值,不可能每次查詢都去做一次 SUM,這意味著需要做多張表的 SUM 操作,效率會很低,而且掘力值的計算還涉及到更為復雜的計算方法(與文章的瀏覽量和點贊數有關)。因此,可以猜測一下大致的表設計,這樣在查詢用戶個人主頁信息的時候只需要從這一張表就可以讀取到所有數據了。

CREATE t_user_summay ( id INT PRIMARY KEY, user_id BIGINT(20), focused_user_cnt INT, followed_user_cnt INT, user_value INT, user_level ENUM(’Lv1’, ’Lv2’, ..., ’Lv8’), created_time DATETIME, updated_time DATETIME,);

MySQL 如何設計統計數據表

是否需要實時更新

在實際應用過程中,統計表有兩種方式,一種是實時更新,一種是周期性的重建數據。兩種方式有利有弊,實時更新保證了查詢數據的即時性,但是會犧牲性能,并且要求代碼埋點,而且由于數據更新是沒有規律的,可能產生碎片。周期性的重建數據犧牲了實時性,如果說大部分數據都不變的話會帶來不必要的統計計算,但如果數據經常變動,那周期性地重建數據顯然會更高效而且避免了埋點的情況。當然,避免應用程序的埋點也可以通過觸發器來完成,可以參考//www.jb51.net/article/213062.htm

物化視圖工具(Flexviews)

在 MySQL 中,有一個 Flexviews 的開源工具用于從數據庫的binlog 中提取數據完成數據統計。有點類似與視圖,但與視圖所不同的是,Flexviews 產生的數據表是物理表,這也是為什么稱之為物化視圖的原因。而且,Flexviews 還支持增量更新和全量更新。推薦使用增量更新,以避免所有行的統計數據都需要重建的情況。增量更新會檢查哪些數據行數據發生了改變,再執行更新操作,相比全量更新而言性能會更高。但為了檢測數據改變,需要引入一個視圖記錄數據行的變化日志。

計數表

在實際開發中,我們經常會需要對一些操作進行計數,比如文章的閱讀數、點贊數。如果將計數值放入同一張表很可能在更新的時候出現并發問題。使用獨立的計數表可以避免查詢緩存失效問題并使用一些更高級的技巧。例如統計文章的閱讀數、點贊數的數據表:

CREATE TABLE t_article_counter ( article_id INT PRIMARY KEY, read_cnt INT UNSIGNED NOT NULL, praise_cnt INT UNSIGNED NOT NULL);

在更新閱讀數的時候,可以使用 MySQL 的內置加1操作:

UPDATE t_article_counter SET read_cnt = read_cnt + 1WHERE article_id = 1;

這種方式可以使得操作是單行的,對事物而言是互斥的,因此會將事務序列化處理避免并發問題。但是卻會影響并發請求量。可以對文章增加多個插槽來提高并發量。

CREATE TABLE t_article_counter ( id INT NOT NULL PRIMARY KEY, slot TINYINT UNSIGNED, article_id INT, read_cnt INT UNSIGNED NOT NULL, praise_cnt INT UNSIGNED NOT NULL, INDEX(article_id));

這時可以創建100個插槽初始化數據,在更新的時候可以這樣操作:

UPDATE t_article_counterSET read_cnt = read_cnt + 1 WHERE slot = RAND() * 100 AND article_id = 1;

獲取某篇文章的總閱讀數時,需要使用一個 SUM 操作:

SELECT SUM(read_cnt) FROM t_article_counterWHERE article_id = 1;

這種方式實際上是空間換時間,提高了并發量。

總結

本篇介紹了如何設計統計數據表,關鍵的核心在于業務類型。對于更新頻率低、數據量小的表使用實時同步或者直接 SUM 求和問題都不大。而對于大數據表,高頻率的更新的情況,則可以使用獨立的統計表。同時,若存在高并發的情況,統計表中可以考慮每項主體增加多個插槽的方式提高并發量。如果是周期性地同步數據,也可以使用 Flexviews 物化視圖插件實現。

以上就是MySQL 如何設計統計數據表的詳細內容,更多關于MySQL 設計統計數據表的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲精品在线国产| 欧美日韩一视频区二区| 国产精品一区二区三区av | 日本一区二区高清不卡| 都市激情国产精品| 久久久777| 日韩在线播放一区二区| 亚洲精品系列| 国产精品资源| 日韩精品诱惑一区?区三区| 亚洲成av人片一区二区密柚| 欧美香蕉视频| 国产亚洲毛片在线| 日韩av午夜在线观看| 日本欧美一区| 动漫av一区| 亚洲欧美不卡| 免费观看亚洲天堂| 国产高清久久| 国产日韩视频| 欧美不卡视频| 欧美亚洲一区二区三区| 精品视频一区二区三区四区五区 | 日韩精品成人| 伊人精品久久| 国产一区调教| 在线看片日韩| 久久天堂精品| 久久超碰99| 亚洲免费播放| 国产精品色在线网站| 91精品二区| 精品午夜视频| 婷婷综合一区| 亚洲精品永久免费视频| 日精品一区二区三区| 日韩精品看片| 国产精品一区二区99| 国产农村妇女精品一区二区| 国产一区二区三区国产精品| 亚洲免费毛片| 亚洲免费播放| 欧美日韩在线网站| sm久久捆绑调教精品一区| 午夜精品福利影院| 亚洲欧美久久| 美女毛片一区二区三区四区| 国产91在线播放精品| 欧美日韩亚洲一区在线观看| 亚洲少妇一区| 悠悠资源网久久精品| 亚洲婷婷在线| 亚洲91视频| 大香伊人久久精品一区二区| 免费精品一区| 亚洲一级大片| 日韩一区二区免费看| 亚洲激情中文在线| 在线视频日韩| 亚洲一区二区三区高清不卡| 国产在线不卡| 免费中文字幕日韩欧美| 激情91久久| 亚洲成人va| av在线日韩| 欧美91视频| 日韩不卡在线观看日韩不卡视频 | 日韩免费看片| se01亚洲视频| 成人av动漫在线观看| 免费精品视频| 国产精品一区二区精品 | 蜜桃视频一区二区三区| 亚洲免费观看高清完整版在线观| 色8久久久久| 精品国产乱码久久久久久1区2匹| 免费亚洲一区| 色88888久久久久久影院| 色吊丝一区二区| 先锋亚洲精品| 国产乱码精品| 成人免费网站www网站高清| 欧美特黄一区| 欧美日韩夜夜| 欧美一区久久久| 亚洲精品精选| 国产成人精品一区二区三区免费| 中文另类视频| 亚洲最新av| 私拍精品福利视频在线一区| 国产精品嫩草99av在线| 国产九一精品| 中文亚洲欧美| 国产精品久久久久av蜜臀| 亚洲视频综合| 精品日韩一区| 亚洲人妖在线| 91久久久精品国产| 精品一区二区三区免费看| 国产亚洲高清视频| 国产成人1区| 久久国产精品免费一区二区三区| 伊人久久大香线蕉av不卡| 国产精品片aa在线观看| 首页欧美精品中文字幕| sm捆绑调教国产免费网站在线观看| 亚洲视频二区| 国产视频一区欧美| 综合日韩av| 国产精品一区二区三区美女| 欧美网站在线| 欧美成人久久| 欧美一区二区性| 91亚洲人成网污www| 国产精品多人| 日韩欧美久久| 香蕉成人久久| 99视频+国产日韩欧美| 福利在线免费视频| 久久99精品久久久野外观看| 日韩有码av| 无码日韩精品一区二区免费| 亚洲中字黄色| 亚洲视频www| 在线视频精品| 婷婷精品进入| 首页欧美精品中文字幕| 亚洲综合不卡| 亚洲精品福利| 日韩不卡免费视频| 综合五月婷婷| 91精品国产一区二区在线观看 | av中文资源在线资源免费观看| 精品中国亚洲| 亚洲综合电影| 婷婷综合网站| 国产午夜久久| 日韩成人av影视| 美女久久久久久| 久久激情婷婷| 亚洲精一区二区三区| 国产精品毛片aⅴ一区二区三区| 久久精品免费看| 99精品电影| 蜜桃免费网站一区二区三区| 日韩美女国产精品| 精品一区二区三区中文字幕视频| 精品三级在线观看视频| 激情久久久久久| 亚州国产精品| 日韩国产综合| 精品中文字幕一区二区三区av| 中文字幕免费精品| 久久尤物视频| 午夜一级久久| 国产中文在线播放| 亚洲久久一区| 国产伦久视频在线观看| 久久不射网站| 久久影视三级福利片| 午夜日韩福利| 精品久久美女| 在线精品亚洲| 激情视频网站在线播放色| 在线综合亚洲| 成午夜精品一区二区三区软件| 免费福利视频一区二区三区| 香蕉精品999视频一区二区| 免费亚洲一区| 日韩影片在线观看| 最新日韩欧美| 国产精品亚洲一区二区三区在线观看| 综合激情视频| 香蕉国产精品| 91精品亚洲| 日韩av有码| 欧美1区二区| 日韩三级一区| 蜜桃视频在线观看一区二区| 久久久夜精品| 91综合网人人| 日本在线不卡视频| 久久电影一区| 亚洲一区二区三区四区五区午夜 | 亚洲精品第一| 久久亚洲不卡| 日韩午夜在线| 午夜一级久久| 国产国产精品| 欧美69视频| 久久激情中文| 成人欧美一区二区三区的电影| 国产精品亚洲欧美日韩一区在线 | 午夜在线视频一区二区区别| 国产一区欧美| 亚洲欧美日韩精品一区二区| 尤物精品在线| 久久亚洲一区| 天堂精品久久久久| 国产精品手机在线播放|