這篇文章主要介紹了數(shù)據(jù)庫三范式和反范式是什么,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
公司主營業(yè)務(wù):網(wǎng)站設(shè)計制作、做網(wǎng)站、移動網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。成都創(chuàng)新互聯(lián)公司是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊有機(jī)會用頭腦與智慧不斷的給客戶帶來驚喜。成都創(chuàng)新互聯(lián)公司推出萬秀免費(fèi)做網(wǎng)站回饋大家。
在日常開發(fā)過程中,我們需要對MySQL數(shù)據(jù)庫進(jìn)行操作,這就涉及到表的構(gòu)建,如何創(chuàng)建一個結(jié)構(gòu)良好的數(shù)據(jù)庫表,就需要遵循以下3個數(shù)據(jù)庫范式。
1. 第一范式
確保數(shù)據(jù)表中每列(字段)的原子性。
如果數(shù)據(jù)表中每個字段都是不可再分的最小數(shù)據(jù)單元,則滿足第一范式。
例如:user用戶表,包含字段id,username,password
2. 第二范式
在第一范式的基礎(chǔ)上更進(jìn)一步,目標(biāo)是確保表中的每列都和主鍵相關(guān)。
如果一個關(guān)系滿足第一范式,并且除了主鍵之外的其他列,都依賴于該主鍵,則滿足第二范式。
例如:一個用戶只有一種角色,而一個角色對應(yīng)多個用戶。則可以按如下方式建立數(shù)據(jù)表關(guān)系,使其滿足第二范式。
user用戶表,字段id,username,password,role_id
role角色表,字段id,name
用戶表通過角色id(role_id)來關(guān)聯(lián)角色表
3. 第三范式
在第二范式的基礎(chǔ)上更進(jìn)一步,目標(biāo)是確保表中的列都和主鍵直接相關(guān),而不是間接相關(guān)。
例如:一個用戶可以對應(yīng)多個角色,一個角色也可以對應(yīng)多個用戶。則可以按如下方式建立數(shù)據(jù)表關(guān)系,使其滿足第三范式。
user用戶表,字段id,username,password
role角色表,字段id,name
user_role用戶-角色中間表,id,user_id,role_id
像這樣,通過第三張表(中間表)來建立用戶表和角色表之間的關(guān)系,同時又符合范式化的原則,就可以稱為第三范式。
4. 反范式化
反范式化指的是通過增加冗余或重復(fù)的數(shù)據(jù)來提高數(shù)據(jù)庫的讀性能。
例如:在上例中的user_role用戶-角色中間表增加字段role_name。
反范式化可以減少關(guān)聯(lián)查詢時,join表的次數(shù)。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“數(shù)據(jù)庫三范式和反范式是什么”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!
分享標(biāo)題:數(shù)據(jù)庫三范式和反范式是什么
文章網(wǎng)址:http://vcdvsql.cn/article20/iigdjo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、關(guān)鍵詞優(yōu)化、網(wǎng)站營銷、面包屑導(dǎo)航、網(wǎng)站設(shè)計公司、企業(yè)網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)