數據庫系統概論期末經典大題講解(范式提升、求閉包、求主碼)

上一次我們介紹了數據庫中關系代數查詢,從選擇、投影到連接等操作符,探索了數據庫查詢
大家可以移步我的文章:數據庫系統概論期末經典大題講解(用關系代數進行查詢)-CSDN博客
今天,我們將繼續沿著數據庫系統的精髓探索之路,深入研究數據庫系統概論中的經典大題:范式、閉包和主碼。讓我們深入挖掘這些概念,并為期末考試做好充分準備


目錄

一.范式提升

1NF

2NF?

3NF

BCNF

綜合例子:?

二.求閉包

三.求主碼


一.范式提升

1NF

關系R中每個分量都是不可分割的數據項,則R屬于1NF

2NF?

定義 若R屬于1NF,且每個非主屬性完全函數依賴于碼,則稱R屬于2NF。?

?該關系模式屬于1NF,不屬于2NF。 因為有非主屬性部分函數依賴于碼:

  • 非主屬性Sdept、 Sloc部分函數依賴于碼

方法:

非主屬性有兩種: 一種完全依賴于碼;

???????????????????????????一種部分依賴于碼 --- 將其分出?

就是完全依賴的單獨作為一個關系模式,部分依賴的將部分依賴費主碼和非主屬性作為一個關系模式

?可變為SC(SNO, CNO, G)? ? S-L(SNO, SDEPT, SLOC) ?此時便是2NF

3NF

定義:若R屬于2NF, 且它的任何一個非主屬性都不傳遞依賴于任何候選碼,則R屬于3NF

(不能有傳遞依賴)

上述例子存在? SNO->SDEPT? ?,? SDEPT->SLOC?(存在傳遞依賴了,不是3NF)

規范化過程中通過一組投影分解消除傳遞依賴,建議作如下分解(第二步分解):

已知關系R(A,B,C), A為主碼(A->B, A->C),且B->C, ?? ?

則將R分解成為兩個投影: ?? ??? ?R1(B,C), B為主碼 ?? ??? ?R2(A,B), A為主碼,B為外碼

?據此可分解為:SC(SNO, CNO, G)? ? S-L1(SNO, SDEPT,)? S-L2(SDEPT, SLOC)

BCNF

關系模式R中每一個決定因素都包含(或是)碼,則R屬于BCNF?

綜合例子:?

某書店購書情況匯總登記表 :

根據分析可以得到一組函數依賴: F={ NO→C#,C#→CN,C#→CA,B#→BN,B#→EU,B#→UP,(NO,B#) →QUA },表中(NO,B#)為關鍵字

?先升級為2NF

? ??

再分解為3NF

? ? ? ? ? ??


二.求閉包

在關系模式R<U, F>中為F所邏輯蘊含的函數依賴的全體叫做F的閉包,記為F+

?

設F為屬性集U上的一組函數依賴,X屬于U, X+F={A|X ->A能由Armstrong公理導出}, X+F稱為屬性集X關于函數依賴F的閉包

步驟:?

?eg:

?


三.求主碼

設關系模式R<U, F> (1) 將R的所有屬性分為 L、 R、N和 LR四類?

1.? ?

  • L類: 僅出現在F的函數依賴左部的屬性; ? ?
  • R類: ………………………...右…………; ? ?
  • N類: 在F的函數依賴左右兩邊都不出現的屬性; ? ?
  • LR類: …………………………都出現的屬性

2.

  • 開始求L類中單個屬性的閉包 ,如果最后結果是全部屬性,那個那個屬性即為主碼
  • 所有單個屬性都不能達到結果,那就開始找多個屬性結合的閉包(從2到n慢慢增加,直到結果是全部屬性)
  • 如果L類中用完了都不行,那就加上N類屬性,先加一個,不行在增加。
  • 如果L+N都不行,最后加上LR類吧(當然老師不會出那么復雜的,一般頂多加上N類就行了)

?

eg:

設關系模式R(A, B, C, D, E, P), 其函數依賴集: ? ??F={A→D, E→D, D→B, BC→D, DC→A} ? ?

求R的所有候選碼。

解: ?L類: C, E ? ? ? ? ?

R類: ? ? ? ? ?

N類: P ? ? ? ? ? ?

LR類: A, B, D

因為(CEP)F+=CEPDBA,所以CEP是R的唯一候選碼


那么今天就先到這里了,之前寫博客都是用富文本,今天發現好多符號都不能打出,影響大家的觀感,只能截圖進來,看來要去學習學習markdown了。希望下次能學會markdown來有更好的格式吧

?

?

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/209680.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/209680.shtml
英文地址,請注明出處:http://en.pswp.cn/news/209680.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

《python每天一小段》--12 數據可視化《1》

歡迎閱讀《Python每天一小段》系列&#xff01;在本篇中&#xff0c;將使用Python Matplotlib實現數據可視化的簡單圖形。 一、概念 Matplotlib是一個流行的Python數據可視化庫&#xff0c;它提供了豐富的繪圖功能&#xff0c;可以創建各種類型的圖表&#xff0c;包括折線圖、…

Spring框架學習:Bean生命周期

目錄 SpringBean的生命周期 Bean實例屬性填充 三級緩存 常用的Aware接口 Spring IoC容器實例化Bean總結 SpringBean的生命周期 Spring Bean的生命周期是從 Bean 實例化之后&#xff0c;即通過反射創建出對象之后&#xff0c;到Bean成為一個完整對象&#xff0c;最終存儲到…

【MyBatis系列】MyBatis字符串問題

&#x1f49d;&#x1f49d;&#x1f49d;歡迎來到我的博客&#xff0c;很高興能夠在這里和您見面&#xff01;希望您在這里可以感受到一份輕松愉快的氛圍&#xff0c;不僅可以獲得有趣的內容和知識&#xff0c;也可以暢所欲言、分享您的想法和見解。 推薦:kwan 的首頁,持續學…

SpringBoot + Spring Cloud Alibaba + Nacos實現服務管理

1、參考文檔 Spring Cloud Alibaba參考文檔 https://spring-cloud-alibaba-group.github.io/github-pages/hoxton/zh-cn/index.html Spring Cloud Alibaba官方文檔 https://github.com/alibaba/spring-cloud-alibaba/wiki/ 2、引入 Alibaba 依賴 每個 SpringBoot 都有對應的…

css中2D和3D的區別

CSS中2D和3D的主要區別在于&#xff1a; 維度不同&#xff1a;2D是二維平面&#xff0c;3D是三維空間。可視角度不同&#xff1a;2D只能從一個平面角度看&#xff0c;而3D可以在多個角度上觀察。技術難度不同&#xff1a;3D效果需要更復雜的技術支持&#xff0c;如矩陣變換&am…

javascript實現Stack(棧)數據結構

上一篇文章我們理解了List這種數據結構&#xff0c;知道了它的特點和一些使用場景&#xff0c;這篇文章我們就來看一下棧這種數據結構&#xff0c;這里的棧可不是客棧哦&#xff0c;哈哈 棧其實和List非常像&#xff0c;使用javascript實現都是基于數組來實現 嘗試理解Stack …

6種常見的JS模塊打包器

前言 JS模塊打包器是一種工具&#xff0c;它可以將多個JS文件或模塊合并成一個或多個輸出文件&#xff0c;以便在瀏覽器或其他環境中使用。 JS模塊打包器的作用有&#xff1a; 優化代碼&#xff1a;通過壓縮、混淆、刪除無用代碼等方式&#xff0c;減少代碼的體積和復雜度&…

windows系統和虛擬機上ubuntu系統通過虛擬串口進行通信

本文的目的是實現windows系統和虛擬機上安裝的ubuntu通過串口進行通信。為了直觀觀測串口收發數據的內容&#xff0c;需要在windows系統和ubuntu系統使用串口助手來進行監聽。windows系統端用的監聽工具是串口助手SSCOM&#xff0c;ubuntu系統端使用的串口助手是CuteCom。 ubu…

OpenCL學習筆記(一)開發環境搭建(win10+vs2019)

前言 異構編程開發&#xff0c;在高性能編程中有重要的&#xff0c;筆者本次只簡單介紹下&#xff0c;如何搭建簡單的開發環境&#xff0c;可以供有需要的小伙伴們開發測試使用 一、獲取opencl的sdk庫 1.使用cuda庫 若本機有Nvidia的顯卡&#xff0c;在安裝cuda庫后&#x…

如何提高大模型在超長上下文的表現?Claude實驗表明加一句prompt立即提升效果~

本文來自DataLearnerAI官方網站&#xff1a;如何提高大模型在超長上下文的表現&#xff1f;Claude實驗表明加一句prompt立即提升效果~ | 數據學習者官方網站(Datalearner)https://www.datalearner.com/blog/1051701947131881 Claude 2.1版本的模型上下文長度最高拓展到200K&am…

【Flink系列四】Window及Watermark

3.1、window 在 Flink 中 Window 可以將無限流切分成有限流&#xff0c;是處理有限流的核心組件&#xff0c;現在 Flink 中 Window 可以是時間驅動的&#xff08;Time Window&#xff09;&#xff0c;也可以是數據驅動的&#xff08;Count Window&#xff09;。 Flink中的窗口…

c jpeg YUV圖片幀分割成 8*8 塊 ,與逆向把8*8還原為幀

1. 正向分割為若干8*8 塊 下面的程序為通用程序&#xff0c;可以分割任意塊 #include <stdlib.h> #include <string.h> #include <stdio.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <stdlib.h>…

如果微軟20年前開發.net core,JAVA會不會和IE一樣倒下了

可以跨平臺&#xff0c;大量類庫&#xff0c;微軟親自操刀&#xff0c;性能一流&#xff0c;因為沒有做跨平臺&#xff0c;.NET被 python,javascript等搶了一半以上市場。 如果微軟早早的推出類似.net core這樣的跨平臺語言&#xff0c;.net程序猿還會出在這樣的尷尬局面嗎眾所…

Java基礎-開發流程以及HelloWorld程序

目錄 1. Java的開發流程2. HelloWorld 1. Java的開發流程 開發Java程序&#xff0c;需要三個步驟&#xff1a;編寫代碼&#xff0c;編譯代碼&#xff0c;運行代碼 2. HelloWorld 編寫代碼 public class HelloWorld {public static void main(String[] args) {System.out.pri…

Ribbon 饑餓加載

Ribbon默認是采用懶加載&#xff0c;即第一次訪問時才會去創建LoadBalanceClient&#xff0c;請求時間會很長而饑餓加載則會在項目啟動時創建&#xff0c;降低第一次訪問的耗時&#xff0c;通過下面配置開啟饑餓加載: 一、懶加載 Ribbon 默認為懶加載即在首次啟動Application…

代碼隨想錄二刷 |二叉樹 | 二叉樹的層序遍歷

代碼隨想錄二刷 &#xff5c;二叉樹 &#xff5c; 二叉樹的層序遍歷 題目描述解題思路代碼實現 題目描述 102.二叉樹的層序遍歷 給你二叉樹的根節點 root &#xff0c;返回其節點值的 層序遍歷 。 &#xff08;即逐層地&#xff0c;從左到右訪問所有節點&#xff09;。 示例…

Flask 最佳實踐(一)

Flask是一個輕量級而強大的Python Web框架&#xff0c;它的簡潔性和靈活性使其成為許多開發者的首選。然而&#xff0c;為了確保項目的可維護性和可擴展性&#xff0c;我們需要遵循一些最佳實踐。本文將探討Flask中一些關鍵的最佳實踐。 1. 項目結構 構建一個清晰的項目結構是…

Java實現Socket聊天室

一、網絡編程是什么&#xff1f; 在網絡通信協議下&#xff0c;不同計算機上運行的程序&#xff0c;進行數據傳輸。 應用場景&#xff1a;即時通訊、網游對戰、金融證券、國際貿易、郵件、等等。 不管是什么場景&#xff0c;都是計算機與計算機之間通過網絡進行數據傳輸。 …

軟件測試之接口測試自動化(詳解版)

本著以和大家交流如何實現高效的接口測試為出發點&#xff0c;本文包含了我在接口測試領域的一些方法和心得&#xff0c;希望大家一起討論和分享&#xff0c;內容包括但不僅限于&#xff1a; 服務端接口測試介紹接口測試自動化介紹接口測試自動化實踐關于接口測試自動化的思考…

質量工程化,交付快速化

質量和速度之間權衡讓人很難取舍&#xff0c;而通過推進質量工程&#xff0c;以系統化的方式識別和優化系統痛點&#xff0c;可以幫助團隊構建既快又好的精益軟件生產系統。原文: Quality Engineered, Speed Delivered 所有人都想要更快的速度。 但需要解決復雜問題: 權衡質量會…