資料庫的設計(E-R圖,資料庫模型圖,三大範式)

来源:http://www.cnblogs.com/heyongjun1997/archive/2016/01/06/5103199.html
-Advertisement-
Play Games

一.資料庫設計的概念資料庫設計是將資料庫中的數據實體及這些數據實體之間的關係,進行規劃和結構化的過程.二.資料庫設計的重要性如果一個資料庫沒有進行一個良好的設計,那麼這個資料庫完成之後他的缺點是:1.效率會很低2更新和檢索數據時會出現很多問題,反之,一個資料庫被盡心策划了一番,具有良好的設計,那他的...


一.資料庫設計的概念

資料庫設計是將資料庫中的數據實體及這些數據實體之間的關係,進行規劃和結構化的過程.

二.資料庫設計的重要性

如果一個資料庫沒有進行一個良好的設計,那麼這個資料庫完成之後他的缺點是:

1.效率會很低

2更新和檢索數據時會出現很多問題,

反之,一個資料庫被盡心策划了一番,具有良好的設計,那他的優點是:

1.效率會很高.

2.便於進一步擴展.

3.使得應用程式的開發變得更容易.

三.設計資料庫的步驟

1.需求分析階段:分析客戶的業務和數據處理需求.

2.概要設計階段:他主要就是繪製資料庫的E-R圖.

3.詳細設計階段:應用資料庫的三大範式進行審核資料庫的結構.

總結:在進行資料庫的系統分析時,都以下列4點位參考的基本步驟.

01.收集信息.

02.標識實體.

03.標識每個實體需要儲存的詳細信息.

04.標識實體之間的關係.

四.學會繪製E-R圖

繪製E-R圖首先要瞭解什麼是實體,什麼是屬性,什麼是聯繫.

1.首先實體是指現實世界中具有區分其他事物的特征或屬性與其他實體有聯繫的實體,針對於資料庫中的表而言實體是指表中一行一行特定數據,但我們在開發中,也常常把整個表稱為一個實體.

2.屬性可以理解為實體的特征,針對於資料庫中的表而言實體是指表中的列.

3.聯繫是兩個或多個實體之間的關聯關係.

4.實體關係圖:

例:酒店管理系統E-R圖:

五.映射基數

1.一對一:X中的一個實體最對與Y中的一個實體關聯,並且Y中的一個實體最多與X中的一個實體關聯.

Eg:一個人只有一張身份證.

2.一對多:X中的一個實體可以與Y中的任意數量的實體關聯;Y中的一個實體最多與X中的一個實體關聯.

Eg:一個班級有多名學生.

3.多對一:X中的一個實體最多與Y中的一個實體關聯;Y中的一個實體可以與X中的任意數量的實體關聯.

Eg:客人與客房之間的關係,一個客人只能住一間客房.

4.多對多:X中的一個實體可以與Y中的任意數量的實體關聯,反之亦然.

Eg:學生和課程之間的關係,一個學生可以有多門課程,一門課程可以對應多名學生.

六.繪製資料庫模型圖

以酒店管理系統為例:

七.資料庫規範化

如果資料庫沒有進行相應的規範設計,雖然在查詢資料庫可能會比較容易,但有時會造成一些問題,主要的問題如下:

1.信息重覆(會造成儲存空間的浪費及一些其他問題).

2.更新異常(冗餘信息不僅浪費空間,還會增加更新的難度).

3.插入異常

4.刪除異常(在某些情況下,當刪除一行時,可能會丟失有用的信息).

八.三大範式

1.第一範式:

目標是確保每列的原子性.如果每列都是不可再分的最小數據單元,則滿足第一範式.

2.第二範式:

第二範式在第一範式的基礎上更進一層,其目標是確保表中的每列都和主鍵相關,如果一個關係滿足第一範式,並且除了主鍵以外的其他列都依賴與該主鍵.則滿足第二範式.

3.第三範式:

第三範式在第二範式的基礎上更進一層,第三範式的目標是確保每列都和主鍵列直接相關,而不是間接相關.如果一個關係滿足第二範式,並且除了主鍵以外的其他列都這能依賴於主鍵列,列和列之間不存在相互依賴關係,則滿足第三範式.

九.規範性和性能的關係

為了滿足三大範式,我們的數據操作性能會受到相應的影響,所以,在實際的資料庫設計中,既要考慮三大範式,避免數據的冗餘和各種數據操作異常;有要考慮到數據訪問性能,有時,為了減少表間連接,提高資料庫的訪問性能,允許適當的數據冗餘列,這可能是最合適的資料庫設計方案.


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

-Advertisement-
Play Games
更多相關文章
  • 編寫者:龍詩科 郵箱:[email protected] gdb 是Linux 下預設的調試工具,當編譯一個程式文件時,如debug.c,要應用gdb調試,必須在終端命令前添加 cc -g或者gcc -g,則編譯debug.c可以用以下命令來得到gcc -g -o d.....
  • uptime命令回顯中的load average所表示的意思和w命令相似,都是表示過去的1分鐘、5分鐘和15分鐘內進程隊列中的平均進程數量。 這裡需要註意的是load average這個輸出值,這三個值的大小一般不能大於系統邏輯CPU的個數,例如,本輸出中系統有4個邏輯CPU,如果loa...
  • /*-----------------------------前奏-----------------------------------*/mcu型號s6e1c32c(48pin)、s6e1c32b(32pin)本次調試:uart0【與SWD 管腳復用】由於在啟動文件中 :跳轉到SystemInit...
  • 之前安裝Ubuntu時,給/boot單獨分了個區,200M...在內核不斷升級之後,這個區域越來越小,導致無法安裝系統更新...然後想到刪除不用的舊內核1. 查看系統現在使用的內核版本uname -a2. 查看系統中已有的內核dpkg --get-selections | grep linux3. ...
  • 編寫者:龍詩科郵箱:[email protected] 眾所周知,windows下的source insight是閱讀項目代碼的神器,其神奇之處在於可以根據當前滑鼠所指的函數名或者變數,來進行全局搜索該函數或變數的定義,而且還會顯示出哪些文件中同樣含有該函數定義,另外可....
  • 本系統是10月5日最新完整版本的Windows10安裝版鏡像,win10正式版,更新了重要補丁,提升應用載入速度,微軟和百度今天宣佈達成合作,百度成為win10Edge瀏覽器中國預設主頁和搜索引擎,系統增加了搜狗輸入法,安裝過程需要用戶手動創建個人賬戶等步驟,為保證系統的穩定性,win10為未激活版...
  • 一.基本概念 我們通俗一點講:Level_triggered(水平觸發):當被監控的文件描述符上有可讀寫事件發生時,epoll_wait()會通知處理程式去讀寫。如果這次沒有把數據一次性全部讀寫完(如讀寫緩衝區太小),那麼下次調用 epoll_w...
  • EXEC sp_addrolemember N'db_owner', N'db'----將db 設置為 db_owner 角色中的一員EXEC sp_droprolemember N'db_owner', N'db'----將db 從 db_owner 角色 去除 ALTER AUTHORIZATI...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...