資料庫基本概念(三)

来源:https://www.cnblogs.com/xhbJava/archive/2019/06/24/11080405.html
-Advertisement-
Play Games

一、資料庫基本概念 1、關係資料庫規範化理論 為使資料庫設計的合理可靠、簡單實用,長期以來,形成了關係資料庫設計理論,即規範化理論。 (1)函數依賴 定義:在表1.1中,描述學生信息時,包括學生的學號、姓名、性別、專業、總學分和備註屬性,由於一個學號對應一名學生,確定了學生學號,一名學生的姓名、性別 ...


一、資料庫基本概念

1、關係資料庫規範化理論

  為使資料庫設計的合理可靠、簡單實用,長期以來,形成了關係資料庫設計理論,即規範化理論。

(1)函數依賴

  • 定義:在表1.1中,描述學生信息時,包括學生的學號、姓名、性別、專業、總學分和備註屬性,由於一個學號對應一名學生,確定了學生學號,一名學生的姓名、性別、專業等屬性也就確定下來,這說明學生姓名、性別、專業、總學分和備註對學生的學號有依賴性,在關係資料庫中稱為函數依賴。即:所謂函數依賴是指關係中一個或一組屬性的值可以決定其它屬性的值。函數依賴正象一個函數 y = f(x) 一樣,x的值給定後,y的值也就唯一地確定了。  
  • 函數依賴的種類:
    1)完全函數依賴和部分函數依賴:

    完全函數依賴:在一個關係中,若某個非主屬性數據項依賴於全部關鍵字稱之為完全函數依賴。

    比如:有一個表,有如下屬性:學生ID,學生姓名,所修課程ID,課程名稱,成績

    完全依賴:(學生ID,所修課程ID)→成績

    成績既不能單獨依賴於學生ID,也不能單獨依賴於所修課程ID,因此成績完全函數依賴於關鍵字。

    (學生ID,所修課程ID)→學生姓名

    部分依賴:學生ID→學生姓名

    學生姓名可以依賴於關鍵字的一個主屬性——學生ID,因此學生姓名部分函數依賴於(學生ID,所修課程ID)。

   2)平凡函數依賴和非平凡函數依賴

    平凡函數依賴:當關係中屬性集合Y是屬性集合X的子集時,存在函數依賴X→Y,即一組屬性函數決定它的所有子集,這種函數依賴稱為平凡函數依賴。

    例如:在在關係學生課程表SC(學生號Sno,課程號 Cno,成績 Grade)中,

    (Sno, Cno) → Sno ,(Sno, Cno) → Cno

    非平凡函數依賴:當關係中屬性集合Y不是屬性集合X的子集時,存在函數依賴X→Y,則稱這種函數依賴為非平凡函數依賴。

    例如:(Sno, Cno) → Grade

     3)傳遞函數依賴

    傳遞函數依賴:設X,Y,Z是關係R中互不相同的屬性集合,存在X→Y(Y !→X),Y→Z,則稱Z傳遞函數依賴於X。

    例:關係S1(學號,系名,系主任)

    學號 → 系名,系名 → 系主任,並且 系名 -\→ 學號,所以 學號 → 系主任 為傳遞函數依賴

(2)範式理論

  範式是資料庫設計中一個重要的過程,通過它可以優化資料庫設計,避免一些問題,可以減少數據冗餘,可以改進資料庫整體組織,可以增強數據的一致性,可以增加資料庫設計的靈活性。因此,在確定設計資料庫之前,還需對資料庫中的表進行範式處理,以確保資料庫遵從適當的範式,從而使設計的資料庫更加規範。

  目前關係資料庫有6種範式:第一範式(1NF)、第二範式(2NF)、第三範式(3NF)、第四範式(4NF)、第五範式(5NF)和第六範式(6NF)。滿足最低要求的是第一範式(1NF)。在第一範式的基礎上滿足更多要求的範式稱為第二範式(2NF),其餘的範式以此類推。一般來說,資料庫只需要滿足第三範式(3NF)即可。

  • 第一範式

  如果關係模式R的每個關係r的屬性都是不可分的數據項,那麼就稱R是第一範式的模式。第一範式是設計資料庫表的最低要求,其最主要的特點是實體的屬性不能再分,映射到表中,就是列(或欄位)不能再分。

  即:一個表中的列是不可再分的(即列的原子性)。

如表1.2,聯繫範式,對於學號‘1001’學生來說,‘聯繫方式’列包含電話和郵箱,可以再分,不符合第一範式要求。

  如表1.3,列不可再分,符合了第一範式要求。

  • 第二範式

  如果關係模式R滿足第一範式,並且R得所有非主屬性都完全依賴於R的每一個候選關鍵屬性,稱R滿足第二範式,簡記為2NF。

  如表1.3,姓名和選修課有對於關係,但是姓名和教材沒有對應關係,選修課程和教材有對對應關係,從而該表不符合第二範式標準。

  將表修改後如表1.4和1.5,符合第二範式標準。

                       

  • 第三範式

  如果關係模式R是2NF,且關係模式R(U,F)中的所有非主屬性對任何候選鍵都不存在傳遞依賴,則成關係R是屬於第三範式的模式。

  如表1.6滿足2NF,但是知道班級後必然能知道該學生 屬於哪個系,所以存在傳遞依賴,不符合3NF規範,所以講班級和系別屬性拆分如表1.7,和1.8,從而符合3NF標準。

表1.6

學號 姓名 班級 系別
1001 張三 電腦科學與技術1班 電腦系
1002 李四 會計1班 經管系

 

表1.7
學號 姓名 班級
1001 張三 電腦科學與技術1班
1002 李四 會計1班

 

表1.8
班級 系別
電腦科學與技術1班 電腦系
會計1班 經管系

  三大範式只是一般設計資料庫的基本理念,可以建立冗餘較小、結構合理的資料庫。如果有特殊情況,當然要特殊對待,資料庫設計最重要的是看需求跟性能,需求>性能>表結構。所以不能一味的去追求範式建立資料庫。

 

 

 

 

 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 初步區分和理解semaphore(信號量), event(事件), lock/mutex(鎖), condition ...
  • 上一篇博文,我們介紹了LCD RGB控制模式的典型時鐘。那麼這一片我們要詳細的去討論剩下的細節部分。 我們先回顧一下之前的典型時序圖 在這個典型的時序圖裡面,除了上篇博文講述的HSYNC VSYNC VDEN VCLK這幾信號外,我們還能看見諸如HSPW、 VSPW,HBPD、 HFPD,VBPD、 ...
  • 一、安裝使用Docer CE 本文以CentOS 7為例,安裝docker CE版本,docker有兩種版本,社區版本CE和企業版本EE,此處學習研究以CE版本為例, 兩種安裝方式可選:1、使用yum安裝,2、使用腳本自動安裝 系統要求 Docker CE 支持 64 位版本 CentOS 7,並且 ...
  • [TOC] 由於標準的ab只支持對單個uri進行壓測,不滿足實際需要,故做以下修改,使ab支持multi url。 1、下載Apache httpd相關源碼包以及針對ab工具的patch包 ~~~ wget https://mirrors.tuna.tsinghua.edu.cn/apache/ap ...
  • 感謝有奉獻精神的人 轉自:http://www.jb51.net/article/97157.htm 1 查看CPU 1.1 查看CPU個數 # cat /proc/cpuinfo | grep "physical id" | uniq | wc -l 2 **uniq命令:刪除重覆行;wc –l命 ...
  • 這是office受保護視圖導致的原因所造成的,按照以下操作,問題就不是問題了 解決辦法如下: 1、在打開excel2018數據表格時,出現提示“文件已損壞,無法打開”,點擊確定按鈕 2、進入空白程式界面後,在空白程式左上角點擊文件選項 3、在左側欄目文件菜單中點擊最下麵的“選項” 4、在彈出的視窗中 ...
  • 查詢語句 首先, 準備數據, 地址是: https://github.com/cystanford/sql_heros_data, 除了id以外, 24個欄位的含義如下: 查詢 查詢分為單列查詢, 多列查詢, 全部查詢等等: 學習階段可以使用SELECT , 但是在生產環境不要用, 因為效率會非常低 ...
  • EhCache 是一個純Java的進程內緩存框架,具有快速、精幹等特點。是一種廣泛使用的開源Java分散式緩存。主要面向通用緩存,Java EE和輕量級容器。另外Spring 提供了對緩存功能的抽象:即允許綁定不同的緩存解決方案(如Ehcache),但本身不直接提供緩存功能的實現。ehcache是一 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...