人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動態(tài)

數(shù)據(jù)庫分庫分表是什么,什么情況下需要用分庫分表

發(fā)布日期:2022-01-30 17:04 | 文章來源:腳本之家

數(shù)據(jù)量在什么情況下需要分表?

為了保證數(shù)據(jù)庫的查詢效率,當(dāng)數(shù)據(jù)達成一定量時建議進行分表操作

1、oracle

當(dāng)oracle單表的數(shù)據(jù)量大于2000萬行時,建議進行水平分拆。

2、mysql

當(dāng)mysql單表的數(shù)據(jù)量大于1000萬行時,建議進行水平分拆。

單表容量到了1000W以上基本上稍微復(fù)雜一點的SQL都需要仔細優(yōu)化,這時候的SQL耗時主要集中在磁盤IO上,數(shù)據(jù)命令緩存的概率降低,總之不好搞,如果是正常的互聯(lián)網(wǎng)項目,提前分庫分表,在前期能做的先做了,后面會省很多時間處理數(shù)據(jù)遷移的事情,數(shù)據(jù)操作比較頻繁,比如訂單表,可能涉及到的插入和更新操作特別頻繁,特別是大并發(fā)的時候,這時如果只用一個庫,對磁盤的IO和mysql的性能都是一種考驗,所以要分庫分表,把操作頻繁的表和基本信息表分開處理,減小單個數(shù)據(jù)庫的壓力,同時也不影響其他基本信息的讀寫

如果只有一臺服務(wù)器,當(dāng)select很多時,update和delete會被這些select訪問中的數(shù)據(jù)堵塞,等待select結(jié)束,并發(fā)性能不高,此時就要選擇讀寫分離了,主 庫 負(fù) 責(zé) 寫 , 從 庫 負(fù) 責(zé) 讀 \color{#FF0000}{主庫負(fù)責(zé)寫,從庫負(fù)責(zé)讀}主庫負(fù)責(zé)寫,從庫負(fù)責(zé)讀

具體情況根據(jù)數(shù)據(jù)庫服務(wù)器的配置和架構(gòu)有關(guān),僅供參考

3、sqlserver

sqlserver一般如下條件就可以選擇分區(qū)分表操作了

1、表的大小超過2GB。
2、表中包含歷史數(shù)據(jù),新的數(shù)據(jù)被增加都新的分區(qū)中。

當(dāng)一個數(shù)據(jù)表的數(shù)據(jù)量達到千萬級別以后,每次查詢都需要消耗大量的時間,所以當(dāng)表數(shù)據(jù)量達到一定量級后我們需要對數(shù)據(jù)表水平切割。水平分區(qū)分表就是把邏輯上的一個表,在物理上按照你指定的規(guī)則分放到不同的文件里,把一個大的數(shù)據(jù)文件拆分為多個小文件,還可以把這些小文件放在不同的磁盤下。這樣把一個大的文件拆分成多個小文件,便于我們對數(shù)據(jù)的管理。

分庫分表是什么,什么情況下需要用分庫分表

1、什么是分庫分表?

顧名思義,即把存于一個庫的數(shù)據(jù)分散到多個庫中,把存于一個表的數(shù)據(jù)分散到多個表中。

2、什么情況下需要分庫分表?

當(dāng)一個數(shù)據(jù)庫被創(chuàng)建之后,隨著時間的推移和業(yè)務(wù)量的增加,數(shù)據(jù)庫中表以及表中的數(shù)據(jù)量就會越來越多,就有可能出現(xiàn)兩種弊端:(1)數(shù)據(jù)庫的存儲資源是有限的,其負(fù)載能力也是有限的,數(shù)據(jù)的大量積累肯定會導(dǎo)致其處理數(shù)據(jù)的能力下降;(2)數(shù)據(jù)量越多,那么對數(shù)據(jù)的增刪改查操作的開銷也會越來越大,所以,當(dāng)出現(xiàn)如上兩種情況,分庫分表勢在必行。

3、分庫分表的方式

(1)垂直切分

適用場景:如果是因為表的個數(shù)多而讓數(shù)據(jù)多,可以按照功能劃分,把聯(lián)系密切的表切分出來放在同一個庫中(分庫);

如果表的字段太多,可以以列為出發(fā)點,將字段進行拆分(分表);

(2)水平切分

適用場景:如果是因為表中的數(shù)據(jù)量過于龐大,則可以采用水平切分,按照某種約定好的規(guī)則將數(shù)據(jù)切分到不同的數(shù)據(jù)庫中;

必須要根據(jù)當(dāng)前數(shù)據(jù)庫的情況做出合適的選擇,也可以將兩種情況結(jié)合在一起。

4、如何聯(lián)合查找?

分庫分表的結(jié)果會使數(shù)據(jù)分散,不好查詢,主要有兩種查詢方式:

(1)、分步查:先查找主表,然后得到關(guān)聯(lián)表的id,再發(fā)起請求得到關(guān)聯(lián)數(shù)據(jù);

(2)、聯(lián)合查:同時發(fā)起多個查詢請求,然后將所有的結(jié)果集合起來。

到此這篇關(guān)于數(shù)據(jù)庫分庫分表是什么,什么情況下需要用分庫分表的文章就介紹到這了,更多相關(guān)數(shù)據(jù)庫分庫分表內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!

美國服務(wù)器租用

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

實時開通

自選配置、實時開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部