Asp.Net 網(wǎng)站優(yōu)化系列之?dāng)?shù)據(jù)庫優(yōu)化 分字訣 分表(縱向拆分,橫向分區(qū))
更新時間:2010年06月09日 20:25:41 作者:
上篇談了分庫,這一篇我們來分表
1. 縱向分表
縱向分表是指將一個有20列的表根據(jù)列拆分成兩個表一個表10列一個表11列,這樣單個表的容量就會減少很多,可以提高查詢的性能,并在一定程度上減少鎖行,鎖表帶來的性能損耗。
縱向分表的原則是什么呢,應(yīng)該怎樣拆分呢?答案是根據(jù)業(yè)務(wù)邏輯的需要來拆分,對于一張表如果業(yè)務(wù)上分兩次訪問某一張表其中一部分?jǐn)?shù)據(jù),那么就可以根據(jù)每次訪問列的不同來做拆分; 另外還可以根據(jù)列更新的頻率來拆分,例如某些列每天要更新3次,有些列從創(chuàng)建開始基本上很少更新。
舉例:
假定場景,我有一張用戶表,這張表包含列:
ID, UserName, Password, RealName, Gender, Email, IsEmailValid, Birthday, Country, City, Address, Mobile, Phone, ZipCode, Hometown, OfficePhone, Company, Position, Industry, LatestLoginTime, LatestLoginIP, LoginTimes,OnlineMinutes
假定現(xiàn)在我們的登錄出現(xiàn)了性能問題,用戶登錄經(jīng)常出現(xiàn)數(shù)據(jù)庫超時的現(xiàn)象。我們打算用拆表的方法解決這個問題。先看下涉及到登錄的字段有:UserName,Password,LatestLoginTime,LatestLoginIP,LoginTimes;那么我們就可以以此為依據(jù)將原表拆分為:UserLogin和UserBase 兩個表,后者包含除了登錄信息的其他列信息;兩張表都要包含主鍵ID。
2. 橫向分區(qū)
橫向分區(qū)是將表從行的角度拆分,例如將創(chuàng)建時間在05年之前的數(shù)據(jù)放在一個分區(qū)上,將05年到08年之間的數(shù)據(jù)放到另一個分區(qū)上,以此類推。橫向分區(qū)所根據(jù)的列必須在聚集索引上,通常會根據(jù)時間,主鍵id等進行劃分。
橫向分區(qū)將數(shù)據(jù)劃分為不同的區(qū),在根據(jù)分區(qū)列條件進行查詢時可以縮小查詢的范圍,從而提高查詢的性能;另外如果數(shù)據(jù)庫服務(wù)器有多個cpu,則可以通過并行操作獲得更好的性能。
到底要根據(jù)那個列進行橫向的分區(qū)和查詢有關(guān)系,我們在建表的時候需要分析,會根據(jù)那個列進行查詢。
舉例:
1. 訂單是一個實效性很強的實體,我們很少查詢幾年前的訂單數(shù)據(jù),我們就可以在訂單的創(chuàng)建時間列上創(chuàng)建分區(qū)函數(shù)來做分區(qū)。
2. 比如帖子通常情況下只有在首頁推薦的最新的帖子被訪問次數(shù)很多,而幾年前的帖子被訪問的幾率較小,這時候我們可以根據(jù)帖子的主鍵id來做分區(qū),id小于300w的在一個分區(qū)上,id在300到600w之間的在一個分區(qū)上。
有關(guān)分區(qū)的更多信息,請參考高性能網(wǎng)站建設(shè)之 MS Sql Server數(shù)據(jù)庫分區(qū)
有關(guān)如何進行分區(qū),請參考Sql Server 分區(qū)演練
縱向分表是指將一個有20列的表根據(jù)列拆分成兩個表一個表10列一個表11列,這樣單個表的容量就會減少很多,可以提高查詢的性能,并在一定程度上減少鎖行,鎖表帶來的性能損耗。
縱向分表的原則是什么呢,應(yīng)該怎樣拆分呢?答案是根據(jù)業(yè)務(wù)邏輯的需要來拆分,對于一張表如果業(yè)務(wù)上分兩次訪問某一張表其中一部分?jǐn)?shù)據(jù),那么就可以根據(jù)每次訪問列的不同來做拆分; 另外還可以根據(jù)列更新的頻率來拆分,例如某些列每天要更新3次,有些列從創(chuàng)建開始基本上很少更新。
舉例:
假定場景,我有一張用戶表,這張表包含列:
ID, UserName, Password, RealName, Gender, Email, IsEmailValid, Birthday, Country, City, Address, Mobile, Phone, ZipCode, Hometown, OfficePhone, Company, Position, Industry, LatestLoginTime, LatestLoginIP, LoginTimes,OnlineMinutes
假定現(xiàn)在我們的登錄出現(xiàn)了性能問題,用戶登錄經(jīng)常出現(xiàn)數(shù)據(jù)庫超時的現(xiàn)象。我們打算用拆表的方法解決這個問題。先看下涉及到登錄的字段有:UserName,Password,LatestLoginTime,LatestLoginIP,LoginTimes;那么我們就可以以此為依據(jù)將原表拆分為:UserLogin和UserBase 兩個表,后者包含除了登錄信息的其他列信息;兩張表都要包含主鍵ID。
2. 橫向分區(qū)
橫向分區(qū)是將表從行的角度拆分,例如將創(chuàng)建時間在05年之前的數(shù)據(jù)放在一個分區(qū)上,將05年到08年之間的數(shù)據(jù)放到另一個分區(qū)上,以此類推。橫向分區(qū)所根據(jù)的列必須在聚集索引上,通常會根據(jù)時間,主鍵id等進行劃分。
橫向分區(qū)將數(shù)據(jù)劃分為不同的區(qū),在根據(jù)分區(qū)列條件進行查詢時可以縮小查詢的范圍,從而提高查詢的性能;另外如果數(shù)據(jù)庫服務(wù)器有多個cpu,則可以通過并行操作獲得更好的性能。
到底要根據(jù)那個列進行橫向的分區(qū)和查詢有關(guān)系,我們在建表的時候需要分析,會根據(jù)那個列進行查詢。
舉例:
1. 訂單是一個實效性很強的實體,我們很少查詢幾年前的訂單數(shù)據(jù),我們就可以在訂單的創(chuàng)建時間列上創(chuàng)建分區(qū)函數(shù)來做分區(qū)。
2. 比如帖子通常情況下只有在首頁推薦的最新的帖子被訪問次數(shù)很多,而幾年前的帖子被訪問的幾率較小,這時候我們可以根據(jù)帖子的主鍵id來做分區(qū),id小于300w的在一個分區(qū)上,id在300到600w之間的在一個分區(qū)上。
有關(guān)分區(qū)的更多信息,請參考高性能網(wǎng)站建設(shè)之 MS Sql Server數(shù)據(jù)庫分區(qū)
有關(guān)如何進行分區(qū),請參考Sql Server 分區(qū)演練
您可能感興趣的文章:
- 對于ASP編碼問題的深入研究與最終解決方案
- Asp.Net 網(wǎng)站優(yōu)化系列之?dāng)?shù)據(jù)庫優(yōu)化分字訣上 分庫
- Asp.Net 網(wǎng)站優(yōu)化系列之?dāng)?shù)據(jù)庫優(yōu)化措施 使用主從庫(全)
- asp.net下數(shù)據(jù)庫操作優(yōu)化一例
- asp.net小談網(wǎng)站性能優(yōu)化
- Asp.net 網(wǎng)站性能優(yōu)化二則分享
- ASP.NET性能優(yōu)化之讓瀏覽器緩存動態(tài)網(wǎng)頁的方法
- ASP.NET性能優(yōu)化之減少請求
- asp.net程序優(yōu)化 盡量減少數(shù)據(jù)庫連接操作
- Asp.Net性能優(yōu)化技巧匯總
- Asp編碼優(yōu)化技巧
相關(guān)文章
Visual Studio Debug實戰(zhàn)教程之基礎(chǔ)入門
這篇文章主要給大家介紹了關(guān)于Visual Studio Debug實戰(zhàn)教程之基礎(chǔ)入門的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-09-09
關(guān)于HttpHandler與HttpModule的理解和應(yīng)用方法
本篇文章小編將為大家介紹,關(guān)于HttpHandler與HttpModule的理解和應(yīng)用方法,有需要的朋友可以參考一下2013-04-04
.NET Core單文件發(fā)布靜態(tài)編譯AOT CoreRT的方法詳解
這篇文章主要給大家介紹了關(guān)于.NET Core單文件發(fā)布靜態(tài)編譯AOT CoreRT的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-07-07
.NET下通過HttpListener實現(xiàn)簡單的Http服務(wù)
這篇文章主要為大家詳細介紹了.NET下通過HttpListener實現(xiàn)簡單Http服務(wù)的相關(guān)資料,感興趣的小伙伴們可以參考一下2016-09-09
asp.net MaxLengthValidator 最大長度驗證控件代碼
如果數(shù)據(jù)庫字段為varchar或char類型,ASP.NET控件在可輸入漢字的情況下,MaxLength屬性不能保證在保存到數(shù)據(jù)庫時不發(fā)生截斷錯誤,因此寫了一個最大長度驗證控件,還可用于多行文本框。2009-12-12
C# 中使用iTextSharp組件創(chuàng)建PDF的簡單方法
C# 中使用iTextSharp組件創(chuàng)建PDF的簡單方法,需要的朋友可以參考一下2013-03-03
Asp.Net Core中服務(wù)的生命周期選項區(qū)別與用法詳解
這篇文章主要給大家介紹了關(guān)于Asp.Net Core中服務(wù)的生命周期選項區(qū)別與用法的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11

