亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

站內群發(fā)消息三種不同用戶量的數據庫設計

 更新時間:2023年12月02日 08:47:03   投稿:yin  
很多SNS網站和一部分CMS網站都廣泛地應用了站內信這一模塊,這個看似簡單的東西其實背后隱藏著很多需要設計師重視的設計細節(jié),要做好這個“郵遞員”是很不容易的,本文講述站內群發(fā)消息三種不同用戶量的數據庫設計,逐漸設計一個百萬級用戶量的站內信群發(fā)數據庫

隨著WEB2.0的發(fā)展,用戶之間的信息交互也變得十分龐大,而且實時性要求越來越高。現在很多SNS網站和一部分CMS網站都廣泛地應用了站內信這一模塊,這個看似簡單的東西其實背后隱藏著很多需要設計師重視的設計細節(jié),要做好這個“郵遞員”是很不容易的。本文講述站內群發(fā)消息三種不同用戶量的數據庫設計,逐漸設計一個百萬級用戶量的站內信群發(fā)數據庫,看完以后你就會明白什么是真正可靠高效的“郵遞員”。

1、幾十——幾百的用戶量

這樣的網站規(guī)模最小,可能是一個中小企業(yè)的CMS系統(tǒng),面對這樣的用戶量,我們就不必要考慮短消息數據量太大的問題了,所以按照怎么方便怎么來的原則,群發(fā)就每人復制一條消息數據,這樣用戶可以自己管理自己的消息,可以非常方便進行“已讀、未讀、刪除”等操作。按照這個思路,我們的數據庫設計如下:

表T_Message

1

2

3

4

5

6

Id            bigint      --消息ID

SenderId      bigint      --發(fā)送者ID

ReceiverId    bigint      --接收者ID

SendTime      datetime    --發(fā)送時間

ReadFlag      tinyint     --已讀標志

MessageText   text        --消息正文

這樣,我們接受自己的消息時只要做如下查詢:

1

SELECT * FROM T_Message WHERE ReceiverId=myid

查詢自己的未讀消息只要做如下查詢:

1

SELECT * FROM T_Message WHERE ReceiverId=myid and ReadFlag=0

這種方法很簡單,可能是我們第一個想到的,對于這樣的用戶量的情況這樣的設計確實也足夠了。

2、幾千——幾萬的用戶量

用戶量到了這樣的級哦別,這個網站應該算是比較大了,筆者估計,可能是一個地區(qū)性的SNS網站。那么面對這樣的用戶量,我們又該如何來設計站內信群發(fā)呢?上面第一種思路還行得通嗎?應該這樣說,如果勉強要用上面那種設計,也是可以的,只不過T_Message可能要考慮分區(qū)。但是,大家會不會覺得消息正文復制那么多條對于這樣的用戶量來講空間浪費太大,因為考慮到接收者一般是不修改消息正文的,所以我們可以讓所有接收者共享一條消息正文。具體數據庫設計方法和上面大同小異:

T_Message

1

2

3

4

5

6

Id              bigint      --消息ID

SenderId        bigint      --發(fā)送者ID

ReceiverId      bigint      --接收者ID

SendTime        datetime    --發(fā)送時間

ReadFlag        tinyint     --已讀標志

MessageTextId   bigint      --這里把消息正文內容換成消息正文Id

T_MessageText

1

2

3

Id              bigint      --ID標識

SenderId        bigint      --發(fā)送者ID

MessageText     text        --消息正文

這樣,我們就大大節(jié)省了消息的存儲空間,但是查詢的時候就稍微麻煩一點,就需要進行聯合查詢了,查詢自己的未讀消息可以這樣(意思一下,可能還有更高效的查詢方式):

1

2

3

SELECT T_Message.*,T_MessageText.* FROM T_Message

INNER JOIN T_MessageText ON T_Message.MessageTextId=T_MessageText.Id

WHERE T_Message.ReceiverId=myid AND T_Message.ReadFlag=0

用這種方法除了正文我們不能隨便刪除外,用戶還是可以自己管理自己的消息。

3、百萬級大用戶量

如果一個網站到了百萬級的用戶量了,那我不得不膜拜該網站和網站經營者了,因為經營這樣的網站一直是筆者的夢想:)好了,回歸正題,如果這樣的系統(tǒng)放你面前,讓你設計一個站內信群發(fā)數據庫,你該何去何從,總之,上面兩種常規(guī)的辦法肯定是行不通了的,因為龐大的數據量會讓消息表撐爆,即使你分區(qū)也無濟于事。這時候作為一個系統(tǒng)架構師的你,可能不僅僅要從技術的角度去考慮這個問題,更要從用戶實際情況去著手尋找解決問題的辦法。這里,有一個概念叫“活躍用戶”,即經常登錄網站的用戶,相對于那些一時沖動注冊而接下來又從來不登錄的用戶來說,活躍用戶對網站的忠誠度很高,從商業(yè)的角度來講,忠誠的客戶享受更高端的服務。

根據這個思路,我們來探索一種方法。假設網站有500萬注冊用戶,其中活躍用戶為60萬(這個比例真很不錯了),現在我們要對所有用戶群發(fā)一封致謝信。還是上面兩張表,首先我們可以先往消息表中插入一條群發(fā)標識為-1的消息,這里我們用字段SourceMessageId(原始消息)來標識(-1為原始群發(fā)消息本身,其他則是原始消息id),這樣其實群發(fā)的工作已經完成了,用戶可以看到這條公共的消息了。但是用戶需要有消息的控制權,所以必須讓每個用戶擁有一條自己的消息。要達到這個目的,我們可以讓用戶登錄時檢查是否已經拷貝原始消息,如果沒有拷貝,則拷貝一份原始消息并插入消息表,群發(fā)標識為原始消息的id;如果已經存在原始消息的拷貝,則什么都不做。這樣,我們就只要為這60萬活躍用戶消耗消息空間就可以了。具體數據庫設計如下:

T_Message

1

2

3

4

5

6

7

Id                  bigint      --消息ID

SenderId            bigint      --發(fā)送者ID

ReceiverId          bigint      --接收者ID,如果為原始群發(fā)消息則為-1

SendTime            datetime    --發(fā)送時間

ReadFlag            tinyint     --已讀標志,如果為原始群發(fā)消息則統(tǒng)一為0未讀

SourceMessageId     bigint      --如果為-1則為原始群發(fā)消息,其他則為原始消息id

MessageTextId       bigint      --這里把消息正文內容換成消息正文Id

T_MessageText與上面方法的一樣。

當然,如果你的活躍用戶達到100%,那這種方法相對前一種就沒有優(yōu)勢了,但這種情況基本上不太可能,所以,筆者覺得這種方法來處理大用戶量的消息群發(fā)還是可行的。

4、總結

本文只是大致闡述了實現的原理,很多細節(jié)都忽略沒有考慮,純粹一個設計想法而已,有興趣的朋友可以去自己實踐一下,另外,筆者對數據庫也不是很精通,如果有哪里闡述錯誤的還請指出,讓我們一起進步。

到此這篇關于站內群發(fā)消息三種不同用戶量的數據庫設計的文章就介紹到這了,更多相關站內群發(fā)消息的數據庫設計內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 免費開源數據庫:SQLite、MySQL和PostgreSQL的優(yōu)缺點

    免費開源數據庫:SQLite、MySQL和PostgreSQL的優(yōu)缺點

    對于處理大規(guī)模數據和高并發(fā)訪問的場景,MySQL和PostgreSQL更適合,SQLite在小型應用程序或嵌入式設備中是一種輕量級、簡單和易于使用的選擇,根據具體的應用需求和場景特點,選擇合適的開源關系型數據庫可以提供更好的性能、可擴展性和靈活性
    2024-02-02
  • Mssql,Access的sql經典SQL語句大全

    Mssql,Access的sql經典SQL語句大全

    常用不常用的一些sql語句,對數據庫操作不是很熟練的朋友可以查詢
    2012-03-03
  • postgresql 按小時分表(含觸發(fā)器)的實現方式

    postgresql 按小時分表(含觸發(fā)器)的實現方式

    這篇文章主要介紹了postgresql 按小時分表(含觸發(fā)器)的實現方式,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-01-01
  • SQL注入報錯注入函數圖文詳解

    SQL注入報錯注入函數圖文詳解

    報錯注入是SQL注入的一種,下面這篇文章主要給大家介紹了關于SQL注入報錯注入函數的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-07-07
  • Access轉換成SQL Server需要注意事項整理

    Access轉換成SQL Server需要注意事項整理

    很多朋友想用SQL2000數據庫的編程方法,但是卻又苦于自己是學ACCESS的,對SQL只是一點點的了解而已,這里我給大家提供以下參考---將ACCESS轉化成SQL2000的方法和注意事項
    2008-04-04
  • SQL注入滲透測試以及護網面試題和解答總結

    SQL注入滲透測試以及護網面試題和解答總結

    現在SQL注入仍然是最流行的攻擊方法之一,開發(fā)人員為此頭疼,下面這篇文章主要給大家介紹了關于SQL注入滲透測試以及護網面試題和解答的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-01-01
  • 記一次SQL優(yōu)化的實戰(zhàn)記錄

    記一次SQL優(yōu)化的實戰(zhàn)記錄

    作為開發(fā)人員,我們免不了與sql打交道,有些sql可能在業(yè)務的最開始,執(zhí)行是毫無問題的,但是隨著業(yè)務量的提升以及業(yè)務復雜度的加 深,可能之前的sql就會需要優(yōu)化了,下面這篇文章主要給大家介紹了關于一次SQL優(yōu)化的實戰(zhàn)記錄,需要的朋友可以參考下
    2022-07-07
  • dbeaver批量導出數據到另一個數據庫的詳細圖文教程

    dbeaver批量導出數據到另一個數據庫的詳細圖文教程

    DBeaver是一款數據庫管理軟件,小巧易用,最主要其官方版就可以滿足平常得任務需求,這篇文章主要給大家介紹了關于dbeaver批量導出數據到另一個數據庫的相關資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2024-03-03
  • 復制數據庫表中兩個字段數據的SQL語句

    復制數據庫表中兩個字段數據的SQL語句

    今天為表新添加一個字段,但又想與表中的另一個字段值相同,由于數據過多想通過sql語句實現,經測試下面的這句話確實很好用
    2013-07-07
  • 如何解決VisualSVN Server 安裝提示錯誤 Repositories is not a valid short file name

    如何解決VisualSVN Server 安裝提示錯誤 Repositories is not a valid shor

    最近在程序中安裝VisualSVN Server時,總是提示“'Repositories' is not a valid short file name”這個問題,難為了好長時間,最終解決,下面小編把我的解決辦法分享給大家,供大家參考
    2015-09-09

最新評論