數據庫知識匯總2

一. 范式

定義:范式是符合某一種級別的關系模式的集合。
關系數據庫中的關系必須滿足一定的要求。滿足不同程度要求的為不同范式;
一個低一級范式的關系模式,通過模式分解(schema decomposition)可以轉換為若干個高一級范式的關系模式的集合,這種過程就叫規范化
規范化的目的:減少數據冗余 ( minimal data redundancy )、消除異常(插入、刪除和更新)。

確定關系屬于第幾范式,首先要確定函數依賴候選碼
1NF:屬性不能有多個值或者不能有重復的屬性;(不能有多值屬性
對關系模式的基本要求,不滿足第一范式(1NF)的數據庫就不是關系數據庫
2NF:非主屬性都完全函數依賴于任何一個候選碼(最小的超碼集合),沒有部分函數依賴(子集不能決定)
(候選碼指向每個非主屬性)
3NF: 不存在傳遞函數依賴
BCNF:每個決定屬性都包含候選碼(超碼)(只有兩個屬性的一定是BCNF
如果一個關系數據庫中的所有關系模式都屬于BCNF,那么在函數依賴范疇內,它已實現了模式的徹底分解,達到了最高的規范化程度,消除了插入異常和刪除異常。

最小函數依賴集Fmin

F中的函數依賴均不能由F中其他函數依賴導出,F中各函數依賴左部均為最小屬性集(不存在冗余屬性)。

Fmin求解過程:

  1. 用分解的法則,使F中的任何一個函數依賴的右部僅含有一個屬性;(右邊只能有一個屬性)
  2. 去掉多余的函數依賴:從第一個函數依賴X→Y開始將其從F中去掉,然后在剩下的函數依賴中求X的閉包X+,看X+是否包含Y,若是,則去掉X→Y;否則不能去掉,依次做下去。直到找不到冗余的函數依賴;
  3. 去掉各依賴左部多余的屬性。一個一個地檢查函數依賴左部非單個屬性的依賴。例如XY→A,若要判Y為多余的,則以X→A代替XY→A是否等價?若A?(X)+,則Y是多余屬性,可以去掉。

例子:

????????????????????????????????

LLJD:無損連接分解(依賴關系下的其他信息)
DPD:依賴保持分解(依賴關系本身)

LLJD-DPD-3NF算法:(兩個關系均保持)
輸入:關系模式 R,R 中的 FD F 集。
輸出:無損聯接和依賴項保留分解 D,使得 D 中的每個架構都在 3NF 中。
(1) 找到所有候選鍵;
(2) 計算 Fmin;
(3) 設 X->Ai, i=1,...,m,是 Fmin 中具有相同左側 X 的所有 FD。創建一個關系模式 XUA1U...UAm . ?如果 Am 不是現有關系架構的子架構,則為 D 中;
(4) 如果所有關系模式都不包含 R 的候選鍵,則使用候選鍵形成另一個關系模式。

例子:

????????????????

找候選碼的方法:(畫圖-->畫表格)

如圖畫出圖后,第一行是一定要的,候選碼中一定要有的;第二行是一定不要的;如果第一行的組合能決定R中所有元素,那么該組合是唯一的候選碼,否則則需要和第三行的元素進行組合,此時可能會有多個候選碼。

LLJD-BCNF算法(只能保證一個關系模式):
輸入:關系模式 R,R 中的一組 FD。
輸出:無損聯接分解 D,使得 D 中的每個新架構都在 BCNF 中。

?例子:

????????????????

????????????????

????????????????

注意:每個范式都是針對一張表的,所以比如BCNF只需要該表的決定因素都是該表的候選碼的超碼即可。

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

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

相關文章

C# 設計模式(結構型模式):橋接模式

C# 設計模式(結構型模式):橋接模式 在軟件設計中,我們經常會遇到系統的變化頻繁,或者需要靈活擴展功能的場景。這時,橋接模式(Bridge Pattern)便顯得尤為重要。橋接模式是一個結構型…

Flash Attention V3使用

Flash Attention V3 概述 Flash Attention 是一種針對 Transformer 模型中注意力機制的優化實現,旨在提高計算效率和內存利用率。隨著大模型的普及,Flash Attention V3 在 H100 GPU 上實現了顯著的性能提升,相比于前一版本,V3 通…

【51單片機零基礎-chapter6:LCD1602調試工具】

實驗0-用顯示屏LCD驗證自己的猜想 如同c的cout,前端的console.log() #include <REGX52.H> #include <INTRINS.H> #include "LCD1602.h" int var0; void main() {LCD_Init();LCD_ShowNum(1,1,var211,5);while(1){;} }實驗1-編寫LCD1602液晶顯示屏驅動函…

【網絡】ARP表、MAC表、路由表

ARP表 網絡設備存儲IP-MAC映射關系的表項&#xff0c;便于快速查找和轉發數據包 ARP協議工作原理 ARP&#xff08;Address Resolution Protocol&#xff09;&#xff0c;地址解析協議&#xff0c;能夠將網絡層的IP地址解析為數據鏈路層的MAC地址。 1.主機在自己的ARP緩沖區中建…

Ubuntu22.04雙系統安裝記錄

1.Ubuntu24.04在手動分區時&#xff0c;沒有efi選項&#xff0c;需要點擊分區界面左下角&#xff0c;選擇efi的位置&#xff0c;然后會自動創建/boot/efi分區&#xff0c;改到2GB大小即可。 2.更新Nvidia驅動后&#xff0c;重啟電腦wifi消失&#xff0c;參考二選一&#xff1a…

Python Notes 1 - introduction with the OpenAI API Development

Official document&#xff1a;https://platform.openai.com/docs/api-reference/chat/create 1. Use APIfox to call APIs 2.Use PyCharm to call APIs 2.1-1 WIN OS.Configure the Enviorment variable #HK代理環境&#xff0c;不需要科學上網(價格便宜、有安全風險&#…

【Python其他生成隨機字符串的方法】

在Python中&#xff0c;除了之前提到的方法外&#xff0c;確實還存在其他幾種生成隨機字符串的途徑。以下是對這些方法的詳細歸納&#xff1a; 方法一&#xff1a;使用random.randint結合ASCII碼生成 你可以利用random.randint函數生成指定范圍內的隨機整數&#xff0c;這些整…

leetcode hot 100 跳躍游戲

55. 跳躍游戲 已解答 中等 相關標簽 相關企業 給你一個非負整數數組 nums &#xff0c;你最初位于數組的 第一個下標 。數組中的每個元素代表你在該位置可以跳躍的最大長度。 判斷你是否能夠到達最后一個下標&#xff0c;如果可以&#xff0c;返回 true &#xff1b;否則…

《Vue3實戰教程》40:Vue3安全

如果您有疑問&#xff0c;請觀看視頻教程《Vue3實戰教程》 安全? 報告漏洞? 當一個漏洞被上報時&#xff0c;它會立刻成為我們最關心的問題&#xff0c;會有全職的貢獻者暫時擱置其他所有任務來解決這個問題。如需報告漏洞&#xff0c;請發送電子郵件至 securityvuejs.org。…

01.02周二F34-Day44打卡

文章目錄 1. 這家醫院的大夫和護士對病人都很耐心。2. 她正跟一位戴金邊眼鏡的男士說話。3. 那個人是個圓臉。4. 那個就是傳說中的鬼屋。5. 他是個很好共事的人。6. 我需要一杯提神的咖啡。7. 把那個卷尺遞給我一下。 ( “卷尺” 很復雜嗎?)8. 他收到了她將乘飛機來的消息。9.…

Spring Boot項目中使用單一動態SQL方法可能帶來的問題

1. 查詢計劃緩存的影響 深入分析 數據庫系統通常會對常量SQL語句進行編譯并緩存其執行計劃以提高性能。對于動態生成的SQL語句&#xff0c;由于每次構建的SQL字符串可能不同&#xff0c;這會導致查詢計劃無法被有效利用&#xff0c;從而需要重新解析、優化和編譯&#xff0c;…

【Rust自學】10.2. 泛型

喜歡的話別忘了點贊、收藏加關注哦&#xff0c;對接下來的教程有興趣的可以關注專欄。謝謝喵&#xff01;(&#xff65;ω&#xff65;) 題外話&#xff1a;泛型的概念非常非常非常重要&#xff01;&#xff01;&#xff01;整個第10章全都是Rust的重難點&#xff01;&#xf…

Spark-Streaming有狀態計算

一、上下文 《Spark-Streaming初識》中的NetworkWordCount示例只能統計每個微批下的單詞的數量&#xff0c;那么如何才能統計從開始加載數據到當下的所有數量呢&#xff1f;下面我們就來通過官方例子學習下Spark-Streaming有狀態計算。 二、官方例子 所屬包&#xff1a;org.…

Python 3 輸入與輸出指南

文章目錄 1. 輸入與 input()示例&#xff1a;提示&#xff1a; 2. 輸出與 print()基本用法&#xff1a;格式化輸出&#xff1a;使用 f-string&#xff08;推薦&#xff09;&#xff1a;使用 str.format()&#xff1a;使用占位符&#xff1a; print() 的關鍵參數&#xff1a; 3.…

【SQLi_Labs】Basic Challenges

什么是人生&#xff1f;人生就是永不休止的奮斗&#xff01; Less-1 嘗試添加’注入&#xff0c;發現報錯 這里我們就可以直接發現報錯的地方&#xff0c;直接將后面注釋&#xff0c;然后使用 1’ order by 3%23 //得到列數為3 //這里用-1是為了查詢一個不存在的id,好讓第一…

Swift Combine 學習(四):操作符 Operator

Swift Combine 學習&#xff08;一&#xff09;&#xff1a;Combine 初印象Swift Combine 學習&#xff08;二&#xff09;&#xff1a;發布者 PublisherSwift Combine 學習&#xff08;三&#xff09;&#xff1a;Subscription和 SubscriberSwift Combine 學習&#xff08;四&…

時間序列預測算法---LSTM

目錄 一、前言1.1、深度學習時間序列一般是幾維數據&#xff1f;每個維度的名字是什么&#xff1f;通常代表什么含義&#xff1f;1.2、為什么機器學習/深度學習算法無法處理時間序列數據?1.3、RNN(循環神經網絡)處理時間序列數據的思路&#xff1f;1.4、RNN存在哪些問題? 二、…

leetcode題目(3)

目錄 1.加一 2.二進制求和 3.x的平方根 4.爬樓梯 5.顏色分類 6.二叉樹的中序遍歷 1.加一 https://leetcode.cn/problems/plus-one/ class Solution { public:vector<int> plusOne(vector<int>& digits) {int n digits.size();for(int i n -1;i>0;-…

快速上手LangChain(三)構建檢索增強生成(RAG)應用

文章目錄 快速上手LangChain(三)構建檢索增強生成(RAG)應用概述索引阿里嵌入模型 Embedding檢索和生成RAG應用(demo:根據我的博客主頁,分析一下我的技術棧)快速上手LangChain(三)構建檢索增強生成(RAG)應用 langchain官方文檔:https://python.langchain.ac.cn/do…

[cg] android studio 無法調試cpp問題

折騰了好久&#xff0c;native cpp庫無法調試問題&#xff0c;原因 下面的Deploy 需要選Apk from app bundle!! 另外就是指定Debug type為Dual&#xff0c;并在Symbol Directories 指定native cpp的so路徑 UE項目調試&#xff1a; 使用Android Studio調試虛幻引擎Android項目…