資料庫規範化設計

来源:https://www.cnblogs.com/yrxc/archive/2020/05/25/12955609.html
-Advertisement-
Play Games

操作異常 修改異常、插入異常、刪除異常 數據依賴 數據間的聯繫 函數依賴FD 屬性撿的聯繫,最基本的數據依賴 若確定X,則可以唯一的確定Y,則稱Y依賴於X記X->Y 若X->Y,且Y是X的子集則稱為平凡的函數依賴:平凡的FD 若X->Y且對於任何並且對於X的任何一 個真子集X′,都有X′ Y,則稱Y ...


操作異常

修改異常、插入異常、刪除異常

數據依賴

數據間的聯繫

函數依賴FD

屬性撿的聯繫,最基本的數據依賴

若確定X,則可以唯一的確定Y,則稱Y依賴於X記X->Y

若X->Y,且Y是X的子集則稱為平凡的函數依賴:平凡的FD

若X->Y且對於任何並且對於X的任何一 個真子集X′,都有X′ Y,則稱Y完全函數依賴於X, 記作X→Y

若存在非主屬性確定非主屬性的情況,則存在傳遞函數依賴

規範化設計

在給定應用環境,構造最優資料庫模式

範式

滿足特定要求的關係模式,評價關係模式的優劣

範式可以升級

 

1NF

若每個屬性的值域為原子的,則R屬於1NF

1NF存在插入異常、刪除異常、更新異常和數據冗餘問題

2NF

R滿足1NF且每個非主屬性都完全函數依賴於候選鍵,則屬於2NF

候選鍵:1.可以決定所有屬性,2.不可約,即候選鍵的子集不能決定所有屬性

候選鍵可以使多個屬性的組合

解決方法,將不滿足的表分為多個表

 

3NF

若R屬於2NF且每個非主屬性都不傳遞依賴於候選鍵,則R屬於3NF

即,不存在非主屬性確定非主屬性的情況

解決方法:將傳遞的屬性單獨構造為一個表

 

修正的3NF

所有屬性都不傳遞依賴於候選鍵

大部分3NF都符合修正的3NF

反例:郵編(城市,地址,郵編)

 

 

一個關係如果不滿足3NF是不能使用的

3NF可在相當程度上減輕原關係中的異常和信息冗餘

規範化程度不是越高越好

規範化是一個模式分解的過程,原則為:1.數據等價:無損分解2.語義等價:保持依賴

 

 

 


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

-Advertisement-
Play Games
更多相關文章
  • w命令 功能說明:顯示已經登錄到系統的用戶以及他們正在運行的命令 用法:w [options] user [...] w命令顯示上當前系統上登錄的用戶及其進程的相關信息。 | 選項 | 作用 | | | | | h | 不顯示前兩行信息 | | f | 不顯示用戶從何處登錄系統 | | s | 使用 ...
  • lscpu命令 功能說明:顯示有關CPU架構的信息 用法: lscpu 一些信息的說明: Architecture:指CPU的架構 CPU(s):指CPU的核數 Thread(s) per core:指的每個 Core 的硬體線程數,超線程,數值為1,表示不支持超線程 Core(s) per soc ...
  • nodejs安裝 官網獲得安裝包(二進位文件) 下載Nodejs預編譯包 Linux下安裝Nodejs 解壓文件的 bin 目錄底下包含了 node、npm 等命令,我們可以修改linux系統的環境變數(profile)來設置直接運行命令: 先將重要文件備份: 然後修改/etc/profile 在p ...
  • [root@node01 apache-hive-2.1.1-bin]# bin/hiveSLF4J: Class path contains multiple SLF4J bindings.SLF4J: Found binding in [jar:file:/export/servers/apac ...
  • 題目一 MyISAM和InnoDB的區別,什麼時候選擇MyISAM 參考回答 InnoDB是目前MySQL主流版本(5.6、5.7、8.0)預設的存儲引擎,支持事務、外鍵、行級鎖,對於併發條件下要求數據的一致性,適用於對數據準確性要求高的場景。 MyISAM只支持表級鎖、數據排列是按照插入順序,沒有 ...
  • 本教程適用於centos7.X,redis版本為6.0.3,採用線上安裝方式,安裝好centos後首先確保網路可用 1.安裝下載工具wget yum install wget 1.1.若出現類似以下問題,則可能是預設的yum源不可用 1.2 yum 換源參考: #備份初始源配置 mv /etc/yu ...
  • 1 準備工作 1.1 修改主機名 vim /etc/hosts # 添加對應主機 192.168.28.128 mha1 192.168.28.131 mha2 192.168.28.132 mha3 1.2 關閉防火牆及修改selinux # 關閉防火牆 systemctl stop firewa ...
  • 事務 資料庫併發控制的對象 事務是資料庫的邏輯工作單位 序列中的操作要麼全做,要麼全不做 特性; 原子性 一個事務中的所有操作是不可分割的,要麼全部執行,要麼 全部不執行,這就是事務的原子性。 一致性 一個被成功執行的事務,必須能使DB從一個一致性 狀態變為另一個一致性狀態。 隔離性 是指資料庫中一 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...