資料庫系統原理之資料庫應用設計與開發實例

来源:https://www.cnblogs.com/QiaoPengjun/archive/2023/04/04/17288085.html
-Advertisement-
Play Games

資料庫應用設計與開發實例 第一節 需求描述與分析 在此,結合某高校個性化課程線上選課的實際需求,給出一個簡化的需求分析 一、功能性需求 1 管理員後臺模塊 學生信息管理 教師信息管理 課程信息管理 班級信息管理 2 學生使用模塊 查詢課程 瀏覽所選課程 查詢成績 3 教師使用模塊 我的課程 登分 二 ...


資料庫應用設計與開發實例

第一節 需求描述與分析

在此,結合某高校個性化課程線上選課的實際需求,給出一個簡化的需求分析

一、功能性需求

1 管理員後臺模塊

  • 學生信息管理
  • 教師信息管理
  • 課程信息管理
  • 班級信息管理

2 學生使用模塊

  • 查詢課程
  • 瀏覽所選課程
  • 查詢成績

3 教師使用模塊

  • 我的課程
  • 登分

二、非功能性需求

線上選課系統

瀏覽器/伺服器(B/S) 結構

  • 選課系統質量需求:
    • 可靠性
    • 正確性
    • 相容性
    • 健壯性

第二節 系統設計

自頂向下 功能模塊結構圖

一、功能模塊設計

  • 登錄驗證模塊
  • 管理員後臺模塊
    • 學生信息管理模塊
    • 教師信息管理模塊
    • 課程信息管理模塊
    • 院系信息管理模塊
  • 學生使用模塊
    • 查詢課程模塊
    • 瀏覽已選課程模塊
    • 選課及退選模塊
    • 成績查詢模塊
  • 教師使用模塊
    • 我的課程模塊
    • 登分模塊

二、資料庫設計

1 確定實體

  • 學生實體用於描述學生的基本信息,包括學號、姓名、性別、密碼等信息。
  • 教師實體用於描述教師的基本信息,包括教師工號、姓名、性別、年齡、職稱、密碼登信息。
  • 課程實體用於描述課程的基本信息,包括課程號、課程名、學分、時間、地點、類別、開課學院、限選人數等信息。
  • 院系實體用於描述院系的基本信息,包括院系名稱、辦公地點、教師人數等信息。
  • 系統管理員實體用於描述系統管理員的基本信息,包括姓名、ID號、密碼登信息。

註意:在資料庫設計時,實體的描述信息可根據實際需求進行增加或刪減,如果實體的屬性較多,在構建 E-R 模型時不一定需要把所有的屬性都標識在E-R 模型上,可以另外用文字說明,這樣也使得 E-R 模型簡明清晰,便於分析。

2 局部信息結構

  • 學生-課程 “選修” 多對多(M:N)
  • 教師-課程 “授課” 一對多(1:N)
  • 教師-院系 “屬於” 一對多(1:N)
  • 學生-院系 “屬於” 一對多(1:N)
  • 系統管理員-學生 “管理” 多對多 (M:N)
  • 系統管理員-教師 “管理” 多對多 (M:N)
  • 系統管理員-課程 “管理” 多對多 (M:N)
  • 系統管理員-院系 “管理” 多對多 (M:N)

3 全局信息結構

  • 首先將學生-課程E-R圖、教師-課程E-R圖,教師-院系E-R圖、學生-院系E-R圖合併成為一個較大的局部信息結構。
    • 學生-教師-課程-院系 E-R 圖
  • 將 系統管理員-學生、系統管理員-教師、系統管理員-課程、系統管理員-院系的E-R圖合併成為一個較大的局部信息結構。
    • 系統管理員-學生-教師-課程-院系 E-R 圖
  • 最後,將 學生-教師-課程-院系 E-R 圖和系統管理員-學生-教師-課程-院系 E-R 圖合併成為一個本系統的全局 E-R 圖。

4 邏輯結構與規範化設計

轉換為關係模式,主碼用下劃線標識

  • 學生(學號、姓名、性別、登錄密碼、院系編號)
  • 院系(院系編號、系名、學生人數、教師人數、辦公地點)
  • 教師(職工號、姓名、性別、年齡、職稱、登錄密碼、院系編號)
  • 課程(課程號、課程名稱、課程類別、學分、上課時間、上課地點、開課學院、限選人數、職工號)
  • 系統管理員(ID號、姓名、登錄密碼)
  • 選修(學號、課程號、成績)
  • 管理學生(管理員 ID 號、學號、操作時間)
  • 管理院系(管理員 ID 號、院系編號、操作時間)
  • 管理教師(管理員 ID 號、職工號、操作時間)
  • 管理課程( 管理員 ID 號、課程號、操作時間)

E-R 圖 關係模式 第三範式

院系

院系編碼(院系編號、系名)

院系(院系編號、學生人數、教師人數、辦公地點)

課程

課程編碼(課程號、課程名稱)

課程(課程號、課程類別、學分、上課時間、上課地點、開課學院、限選人數、職工號)

第三節 系統實現

1 資料庫的實現

  • 創建資料庫
mysql> create database db_xuanke;
Query OK, 1 row affected (0.00 sec)

mysql>

  • 創建表
    • 學生信息表 student
    • 院系編碼表 deptcode
    • 院系表 department
    • 教師表 teacher
    • 課程編碼表 coursecode
    • 課程表 course
    • 系統管理員表 administrator
    • 選修表 electing
    • 管理學生表 adminstu
    • 管理院系表 admindept
    • 管理教師表 adminteacher
    • 管理課程表 admincourse

2 系統功能的實現

  • 實現資料庫行為
    • 安全控制
    • 管理學生
    • 資料庫保護
    • 事務與併發控制
    • 數據查詢與統計報表
  • 實現應用軟體的業務邏輯

第四節 系統測試與維護

1 登錄驗證功能測試

2 管理員後臺主要功能測試

  • 學生信息管理功能
  • 課程信息管理功能

3 學生使用模塊功能測試

4 教師使用模塊功能測試

本文來自博客園,作者:QIAOPENGJUN,轉載請註明原文鏈接:https://www.cnblogs.com/QiaoPengjun/p/17288085.html


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

-Advertisement-
Play Games
更多相關文章
  • 閱讀IL主要是為了能夠更好的學會Emit 從控制台開始吧:事先準備工具ILSpy,和IL的命令指南(這個可以網上搜索或者去看OpCode枚舉),記住棧中的都是引用的地址 int i = 10; int j = 20; int k = 30; Console.WriteLine(i + j + k); ...
  • #1. 緩存 緩存指的是在軟體應用運行過程中,將一些數據生成副本直接進行存取,而不是從原始源(資料庫,業務邏輯計算等)讀取數據,減少生成內容所需的工作,從而顯著提高應用的性能和可伸縮性,使用好緩存技術,有利於提高我們提升用戶體驗性。 對於緩存的使用有以下一些註意點: 緩存最適用於不常更改且生成成本很 ...
  • 1.創建一個新的WinForms或WPF應用程式,具體取決於您的需要。 2.將Telerik Reporting組件添加到您的應用程式中。您可以通過NuGet包管理器來完成此操作。 3.在您的應用程式中添加多個報表文件。您可以使用Telerik Report Designer創建報表並將其添加到您的 ...
  • 【目錄】 1 委托 2 事件-概念的引出 3 事件-關於異常 4 事件-關於非同步 5 委托-Func與Action 1 委托 在.NET中定義“委托”需要用到delegate關鍵字,它是存有對某個方法的引用的一種引用類型變數,類似於 C 或 C++ 中函數的指針。“委托”主要有兩大作用: (1)將方 ...
  • 一:背景 1. 講故事 昨天有位朋友找到我,說他的程式記憶體存在泄露導致系統特別卡,大地址也開了,讓我幫忙看一下怎麼回事?今天上午看了下dump,感覺挺有意思,在我的分析之旅中此類問題也蠻少見,算是完善一下體系吧。 二:WinDbg 分析 1. 到底是哪裡的泄露 在.NET高級調試訓練營中,我多次告訴 ...
  • linux的crypt 最近學校佈置了一個網安的小作業,要用到linux裡面的這個crypt函數,寫一篇總結一下。首先我們要瞭解這個函數是用來做什麼的。 密碼影子文件中存儲了每一個用戶的用戶明文和其單向哈希過的秘文 cipher = "$1$C68vnJ27$1ttFZ1/Rylq/xi350A0N ...
  • Redhat7/CentOS7 網路配置與管理(nmtui、nmcli、GNOME GUI、ifcfg文件、IP命令) 背景:作為系統管理員,需要經常處理主機網路問題,而配置與管理網路的方法和工具也有好幾種,這裡整理分享一下網路配置與管理的幾種方式。 1、NetworkManager 概述 在 Re ...
  • MPU6050(三軸MEMS陀螺儀 + 三軸MEMS加速度計 + 數字運動處理器DMP)把姿態解算出來的慣性數據和歐拉角,上報給Processing IDE,或上報匿名上位機(V7),從而實時聯動系統無人機模型的飛行姿態。下麵講一下整個聯調過程以及遇到的坑。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...