mysql 數(shù)據(jù)庫(kù)設(shè)計(jì)
更新時(shí)間:2009年06月14日 14:42:14 作者:
大家都知道m(xù)ysql的myisam表適合讀操作大,寫操作少;表級(jí)鎖表
innodb表正好相反;行級(jí)鎖表
互聯(lián)網(wǎng)服務(wù),不算支付性的服務(wù)外,互動(dòng)產(chǎn)品,新聞系統(tǒng)等等一般都是讀多,寫少。用myisam表比較合適。
表的設(shè)計(jì)
定長(zhǎng)表:所有列的字段長(zhǎng)度都是定長(zhǎng)的??梢匀ゲ閙ysql的手冊(cè)不定長(zhǎng)字段是VARCHAR、BLOB或TEXT。int char都是定長(zhǎng)的,定長(zhǎng)表占用空間會(huì)大。
動(dòng)態(tài)表:就是字段不是都定長(zhǎng)的。
定長(zhǎng)表要比動(dòng)態(tài)表檢索速度快。
軟件系統(tǒng)的設(shè)計(jì)習(xí)慣是把每張表都分清很明確的功能,比如用戶表都是用戶信息,如果需要同時(shí)從留言表取數(shù)據(jù),又從用戶表取用戶信息的時(shí)候,就會(huì)采用聯(lián)合查 詢,有的時(shí)候一些操作還會(huì)用left,join等各種復(fù)雜sql語(yǔ)句,沒(méi)準(zhǔn)還要用mysql的函數(shù)。如果是針對(duì)訪問(wèn)量,讀取量很大的互聯(lián)網(wǎng)服務(wù)時(shí),同時(shí)并 發(fā)去讀,數(shù)據(jù)量又大,很可怕。最好是如果數(shù)據(jù)不會(huì)修改,在常用的表上有冗余字段,能夠做到一次讀,把數(shù)據(jù)都拿到;可以有冗余的寫操作,但減少?gòu)?fù)雜的查詢操 作。
在設(shè)計(jì)表的時(shí)候要將這個(gè)表的所有字段類型占用的字節(jié)數(shù)求和,并乘以你的預(yù)期(如:存儲(chǔ)100W數(shù)據(jù)量),就是整張表未來(lái)會(huì)占用容量。
拆表 拆庫(kù)
拆表就是將一張表復(fù)制N多張,里面分別存放不用內(nèi)容的數(shù)據(jù),數(shù)據(jù)的存放是用HASH算法來(lái)決定放入哪張表。
例如用戶表user,傳統(tǒng)情況就是一張表,拆表就是將表復(fù)制為user_01,user_02等里面都存放了格式一樣的不同用戶數(shù)據(jù)。
拆庫(kù)和拆表類似,就是庫(kù)的復(fù)制。
拆表或拆庫(kù)有很多的HASH算法,主要目的就是減少表的數(shù)據(jù)量,用算法保證每個(gè)表的數(shù)據(jù)量平均,請(qǐng)求,讀寫操作被分?jǐn)偨档蛪毫?,而且安全,出了?wèn)題最多是一部分用戶受影響。缺點(diǎn)就是檢索不方便,需要另想辦法。
很多網(wǎng)站為了前期省事都會(huì)采用discuz的產(chǎn)品,如bbs,blog等,網(wǎng)上有不少關(guān)于這個(gè)產(chǎn)品的介紹和優(yōu)化方法,沒(méi)細(xì)研究過(guò),聽(tīng)過(guò)一些網(wǎng)站介紹他們的 優(yōu)化方法時(shí),對(duì)于數(shù)據(jù)庫(kù)主要是采用主從的方法,將數(shù)據(jù)庫(kù)的讀寫分離來(lái)提高性能,但是個(gè)人覺(jué)得這種辦法在數(shù)據(jù)量到了規(guī)模的時(shí)候就OVER了,并發(fā)和讀寫操作 沒(méi)提升,數(shù)據(jù)也是會(huì)逐漸累計(jì)超過(guò)限制。
互聯(lián)網(wǎng)服務(wù)由于要應(yīng)對(duì)大數(shù)據(jù)量,大請(qǐng)求量,所以在設(shè)計(jì)開(kāi)發(fā)的時(shí)候就不要太學(xué)院派,不要力圖達(dá)到數(shù)據(jù)庫(kù)、程序的設(shè)計(jì)“優(yōu)美”,性能是最要緊的。
互聯(lián)網(wǎng)服務(wù),不算支付性的服務(wù)外,互動(dòng)產(chǎn)品,新聞系統(tǒng)等等一般都是讀多,寫少。用myisam表比較合適。
表的設(shè)計(jì)
定長(zhǎng)表:所有列的字段長(zhǎng)度都是定長(zhǎng)的??梢匀ゲ閙ysql的手冊(cè)不定長(zhǎng)字段是VARCHAR、BLOB或TEXT。int char都是定長(zhǎng)的,定長(zhǎng)表占用空間會(huì)大。
動(dòng)態(tài)表:就是字段不是都定長(zhǎng)的。
定長(zhǎng)表要比動(dòng)態(tài)表檢索速度快。
軟件系統(tǒng)的設(shè)計(jì)習(xí)慣是把每張表都分清很明確的功能,比如用戶表都是用戶信息,如果需要同時(shí)從留言表取數(shù)據(jù),又從用戶表取用戶信息的時(shí)候,就會(huì)采用聯(lián)合查 詢,有的時(shí)候一些操作還會(huì)用left,join等各種復(fù)雜sql語(yǔ)句,沒(méi)準(zhǔn)還要用mysql的函數(shù)。如果是針對(duì)訪問(wèn)量,讀取量很大的互聯(lián)網(wǎng)服務(wù)時(shí),同時(shí)并 發(fā)去讀,數(shù)據(jù)量又大,很可怕。最好是如果數(shù)據(jù)不會(huì)修改,在常用的表上有冗余字段,能夠做到一次讀,把數(shù)據(jù)都拿到;可以有冗余的寫操作,但減少?gòu)?fù)雜的查詢操 作。
在設(shè)計(jì)表的時(shí)候要將這個(gè)表的所有字段類型占用的字節(jié)數(shù)求和,并乘以你的預(yù)期(如:存儲(chǔ)100W數(shù)據(jù)量),就是整張表未來(lái)會(huì)占用容量。
拆表 拆庫(kù)
拆表就是將一張表復(fù)制N多張,里面分別存放不用內(nèi)容的數(shù)據(jù),數(shù)據(jù)的存放是用HASH算法來(lái)決定放入哪張表。
例如用戶表user,傳統(tǒng)情況就是一張表,拆表就是將表復(fù)制為user_01,user_02等里面都存放了格式一樣的不同用戶數(shù)據(jù)。
拆庫(kù)和拆表類似,就是庫(kù)的復(fù)制。
拆表或拆庫(kù)有很多的HASH算法,主要目的就是減少表的數(shù)據(jù)量,用算法保證每個(gè)表的數(shù)據(jù)量平均,請(qǐng)求,讀寫操作被分?jǐn)偨档蛪毫?,而且安全,出了?wèn)題最多是一部分用戶受影響。缺點(diǎn)就是檢索不方便,需要另想辦法。
很多網(wǎng)站為了前期省事都會(huì)采用discuz的產(chǎn)品,如bbs,blog等,網(wǎng)上有不少關(guān)于這個(gè)產(chǎn)品的介紹和優(yōu)化方法,沒(méi)細(xì)研究過(guò),聽(tīng)過(guò)一些網(wǎng)站介紹他們的 優(yōu)化方法時(shí),對(duì)于數(shù)據(jù)庫(kù)主要是采用主從的方法,將數(shù)據(jù)庫(kù)的讀寫分離來(lái)提高性能,但是個(gè)人覺(jué)得這種辦法在數(shù)據(jù)量到了規(guī)模的時(shí)候就OVER了,并發(fā)和讀寫操作 沒(méi)提升,數(shù)據(jù)也是會(huì)逐漸累計(jì)超過(guò)限制。
互聯(lián)網(wǎng)服務(wù)由于要應(yīng)對(duì)大數(shù)據(jù)量,大請(qǐng)求量,所以在設(shè)計(jì)開(kāi)發(fā)的時(shí)候就不要太學(xué)院派,不要力圖達(dá)到數(shù)據(jù)庫(kù)、程序的設(shè)計(jì)“優(yōu)美”,性能是最要緊的。
您可能感興趣的文章:
- PHP+MySQL投票系統(tǒng)的設(shè)計(jì)和實(shí)現(xiàn)分享
- PHP+Mysql樹(shù)型結(jié)構(gòu)(無(wú)限分類)數(shù)據(jù)庫(kù)設(shè)計(jì)的2種方式實(shí)例
- MYSQL 數(shù)據(jù)庫(kù)命名與設(shè)計(jì)規(guī)范
- MySQL分表實(shí)現(xiàn)上百萬(wàn)上千萬(wàn)記錄分布存儲(chǔ)的批量查詢?cè)O(shè)計(jì)模式詳解
- MySQL 數(shù)據(jù)庫(kù)設(shè)計(jì)復(fù)習(xí)筆記及項(xiàng)目實(shí)戰(zhàn)
- 基于PHP+MySQL的聊天室設(shè)計(jì)
- MySQL和MongoDB設(shè)計(jì)實(shí)例對(duì)比分析
- 如何設(shè)計(jì)高效合理的MySQL查詢語(yǔ)句
- MySQL 設(shè)計(jì)和命令行模式下建立詳解
相關(guān)文章
mysql建表報(bào)錯(cuò):invalid?default?value?for?'date'的解決方
最近遇到一個(gè)這樣的問(wèn)題,出現(xiàn)了invalid default value for 'end_date'錯(cuò)誤,所以下面這篇文章主要給大家介紹了關(guān)于mysql建表報(bào)錯(cuò):invalid?default?value?for?'date'的解決方法,需要的朋友可以參考下2022-12-12MySQL數(shù)據(jù)庫(kù)常用操作和技巧(DBA必備知識(shí))
MySQL數(shù)據(jù)庫(kù)可以說(shuō)是DBA們最常見(jiàn)和常用的數(shù)據(jù)庫(kù)之一,為了方便大家使用,老MySQL DBA總結(jié)了MySQL數(shù)據(jù)庫(kù)最常見(jiàn)和最常使用的一些經(jīng)驗(yàn)和技巧,與分享大家!2011-03-03怎么重置mysql的自增列AUTO_INCREMENT初時(shí)值
怎么重置mysql的自增列想必有很多的朋友都不會(huì)吧,下面與大家分享下常用的幾種方法,不懂的朋友可以了解下哈,希望對(duì)大家有所幫助2013-06-06

Mysql ALTER TABLE加字段的時(shí)候到底鎖不鎖表
本文主要介紹了Mysql ALTER TABLE加字段的時(shí)候到底鎖不鎖表,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
2021-08-08 
MySQL數(shù)據(jù)庫(kù)優(yōu)化經(jīng)驗(yàn)詳談(服務(wù)器普通配置)
同時(shí)在線訪問(wèn)量繼續(xù)增大 對(duì)于1G內(nèi)存的服務(wù)器明顯感覺(jué)到吃力嚴(yán)重時(shí)甚至每天都會(huì)死機(jī) 或者時(shí)不時(shí)的服務(wù)器卡一下 這個(gè)問(wèn)題曾經(jīng)困擾了我半個(gè)多月MySQL使用是很具伸縮性的算法,因此你通常能用很少的內(nèi)存運(yùn)行或給MySQL更多的被存以得到更好的性能。
2011-03-03