資料庫設計的步驟

来源:https://www.cnblogs.com/feiyu2/archive/2022/06/23/Database_Design.html
-Advertisement-
Play Games

資料庫設計的設計內容包括:需求分析、概念結構設計、邏輯結構設計、物理結構設計、資料庫的實施和資料庫的運行和維護。 ...


資料庫設計是指:根據用戶的需求,在資料庫管理系統上(比如:MySQL、Oracle),設計資料庫的結構和建立資料庫的過程。

資料庫設計的設計內容包括:需求分析、概念結構設計、邏輯結構設計、物理結構設計、資料庫的實施和資料庫的運行和維護。

需求分析

需求分析是:確定用戶對資料庫系統的使用需求,得到需求描述。

調查和分析用戶的業務活動和數據的使用情況,弄清所用數據的種類、範圍、數量以及它們在業務活動中交流的情況,確定用戶對資料庫系統的使用要求和各種約束條件等,形成用戶需求規約。

需求分析是在用戶調查的基礎上,通過分析,逐步明確用戶對系統的需求,包括數據需求和圍繞這些數據的業務處理需求。

在需求分析中,通過自頂向下,逐步分解的方法分析系統,分析的結果採用數據流程圖進行圖形化的描述。

概念結構設計

概念結構設計是:依據需求描述,建立抽象的概念數據模型。

概念數據模型最常用的是:實體-聯繫模型(E-R模型,Entity Relationship Model)

總結來說,概念結構設計就是:依據需求描述,得到實體-聯繫模型,並畫出 E-R圖。

對用戶要求描述的現實世界(可能是一個工廠、一個商場或者一個學校等),通過對其中諸處的分類、聚集和概括,建立抽象的概念數據模型。

這個概念數據模型應該反映現實世界各部門的信息結構、信息流動情況、信息間的互相制約關係以及各部門對信息儲存、查詢和加工的要求等。

所建立的概念數據模型應該避開資料庫在電腦上的具體實現細節,用一種抽象的形式表示出來。


以擴充的“E-R模型”為例:

  • 第一步:先明確現實世界各部門所含的各種實體及其屬性、實體間的聯繫以及對信息的制約條件等,從而給出各部門內所用信息的局部描述(在資料庫中稱為用戶的局部視圖,即局部 E-R圖)。
  • 第二步:再將前面得到的多個用戶的局部視圖集成為一個全局視圖,即用戶要描述的現實世界的概念數據模型。(即全局 E-R圖)

可參考資料:E-R圖及理論知識

邏輯結構設計

邏輯結構設計是:依據概念數據模型,得到資料庫的邏輯數據模型。

邏輯數據模型最常用的是:關係數據模型。

關係數據模型的邏輯結構是一組關係模式的集合。一個實體轉換為一個關係模式。

總結來說,邏輯結構設計就是:依據 E-R圖,得到一組關係模式。

邏輯結構設計的主要工作是:將現實世界的概念數據模型設計成資料庫的一種邏輯數據模式,即適應於某種特定資料庫管理系統所支持的邏輯數據模式。

邏輯結構設計的結果就是所謂“邏輯資料庫”。

物理結構設計

資料庫的物理結構設計就是:為一個給定的邏輯數據模型選取一個最適合應用要求的物理結構的過程。

  • 資料庫在物理設備上的存儲結構與存取方法稱為資料庫的物理結構。
  • 資料庫的物理結構依賴於選定的資料庫管理系統。

物理結構設計的結果就是所謂“物理資料庫”。


物理結構設計的步驟

資料庫的物理結構設計通常分為兩步:

  1. 確定資料庫的物理結構。(物理結構在關係型資料庫中主要指:存取方法和存儲結構)
  2. 對物理結構進行評價,評價的重點是:時間和空間效率。

如果評價結果滿足原設計要求,則可進入到物理實施階段,否則,就需要重新設計或修改物理結構,有時甚至要返回到邏輯結構設計階段修改邏輯數據模型。


物理結構設計的任務之一是:根據關係型資料庫管理系統支持的存取方法確定選擇哪些存取方法。

存取方法是快速存取資料庫中數據的技術。

資料庫管理系統一般提供多種存取方法,常用的存取方法為:索引方法、聚簇方法。

索引方法有:B+樹索引、hash 索引。

可參考資料:DBSM常用的數據存取方法

資料庫的實施、運行和維護

本文來自博客園,作者:真正的飛魚,轉載請註明原文鏈接:https://www.cnblogs.com/feiyu2/p/Database_Design.html


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

-Advertisement-
Play Games
更多相關文章
  • 搭建yum倉庫需要兩種資源: rpm包 rpm包的元數據(repodata) 搭建好倉庫後需要使用三種網路協議共用出來 http或https ftp 範例: 使用http協議搭建私有倉庫 (本示例使用光碟作為源) #倉庫伺服器配置 yum -y install httpd systemctl ena ...
  • pwd 顯示工作路徑 shutdown -h now 關閉系統 /halt 關閉系統 shutdown -r now 重啟 / reboot 重啟 1、cd命令:這是一個非常基本,也是大家經常需要使用的命令,它用於切換當前目錄,它的參數是要切換到的目錄的路徑,可以是絕對路徑,也可以是相對路徑。如: ...
  • 環境:CentOS/Linux FFmpeg官網:http://www.ffmpeg.org 將安裝到目錄/usr/local/下 mkdir /usr/local/ffmpeg cd /usr/local/ffmpeg wget http://ffmpeg.org/releases/ffmpeg- ...
  • 鏡像下載、功能變數名稱解析、時間同步請點擊 阿裡雲開源鏡像站 準備 作為一個經常在伺服器上游走的後端,需要熟悉不少命令行操作。其中,grep、sed、awk號稱"linux三劍客",使用頻繁,功能強大,本文通過一個實例演示下基本用法。首先準備一個文本文件,命名為text.txt,內容如下: cat text ...
  • 1.官方SDK(帶Freertos)無法編譯和下載解決方案: (1)無法編譯通過:(會報一下奇奇怪怪的錯誤) 32bit MCU官方freertos的SDK編譯不通過可能是基於不同的C語言版本編寫,需要修改配置如下: (2)無法下載:本人遇到的錯誤是這個 “No Algorithm found fo ...
  • 鏡像下載、功能變數名稱解析、時間同步請點擊 阿裡雲開源鏡像站 一、什麼是MQ? 消息隊列(Message Queue,簡稱MQ),從字面意思上看,本質是個隊列,FIFO先入先出,只不過隊列中存放的內容是message而已。 其主要用途:不同進程Process/線程Thread之間通信。 隊列是一種先進先出的 ...
  • 使用yum或dnf解決rpm包的依賴關係。 YUM:Yellowdog Update Modifier。是rpm的前端程式 作用:解決軟體包之間的依賴關係 yum工作原理: yum 伺服器存放rpm包和相關rpm包的元資料庫(一個叫做repodata的文件夾--存放包的列表、依賴關係等信息) yum ...
  • 問題導入 在之前項目的基礎功能實現中,後臺管理和移動端在進行數據訪問的時候,都是直接操作資料庫MySQL。此時的系統有且僅有一臺MySQL伺服器,則可能會出現如下問題 ①、讀和寫所有壓力都由一臺資料庫承擔,壓力大 ②、資料庫伺服器磁碟損壞導致數據丟失,單點故障 解決方案 很簡單,一臺伺服器撐不住,那 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...