基于C+++Mysql实现(CS界面)图书管理系统

news/2024/9/29 1:24:41/

图书管理系统

实验内容、步骤以及结果

做出数据流图和数据字典。

在数据流图和字典的基础上做出 E-R 图(概念结构设计)。

学生:

图书:

管理员:

汇总:

在 E-R 图基础上进行关系模式设计(至少满足 3NF)(逻辑结构设计)。

(图书一共有 4 种状态:

  • 状态 0:在馆内无预订,
  • 状态 1:在馆内有预订,
  • 状态 2:已借出无预订,
  • 状态 3:已借出有预订。)
Book(BookID, Title, Author, Publisher, Pyear, Category, State)

图书(书号,书名,作者,出版社,出版年,分类,状态)

Student(StuID, StuName, Gender, Dept, Class)

学生(学号,姓名,性别,学院,班级)

Librarian(LibID, LibName)

管理员(工号,姓名)

RBorrow(BookID, StuID, BrDate)

预借阅(书号,学号,借阅日期)

RRenew(BookID, StuID, RnDate)

预续借(书号,学号,续借日期)

RReturn(BookID, StuID, RtDate)

预归还(书号,学号,归还日期)

Borrow(BookID, StuID, BrDate)

借阅(书号,学号,借阅日期)

Renew(BookID, StuID, RnDate)

续借(书号,学号,续借日期)

Return(BookID, StuID, RtDate)

归还(书号,学号,归还日期)

根据需求分析中的各种数据请求得出各种视图以及各种约束、规则、触发器脚本描述。

视图:

学生的除密码外的所有信息,供管理员修改。

约束:

  • 所有预订与确认的表中的所有列、书名与作者、学生与管理员姓名为非空;
  • State 只能为 0、1、2、3,默认值为 0.
  • 性别为“男”或“女”。
  • 初始密码为“123456”.

规则:

同一个人不能在一秒之内对同一本书借了还还了借。

触发器:

  • 学生预借阅:判断书此时未被预订,写入预订时间,更新图书状态为已预订;
  • 学生预续借:判断此书已借给相同学生且未被预订,写入续借时间;
  • 学生预归还:判断此书已借给相同学生,写入归还时间;
  • 管理员确认借阅:若在馆内更新相关图书状态为已借出,若已借出则更新为已预订;
  • 管理员确认续借:不更新图书状态;
  • 管理员确认归还:更新图书状态为在馆内。

实验中出现的问题以及解决方案(对于未解决问题请将问题列出来)

开始不会写界面程序,学习了一些 Qt 的操作与语法后逐渐写成,参考:

qmake 编译失败问题:文件路径必须为英文,不能含有中文字符。

Qt 连接 MySQL 驱动出错问题 QMYSQL driver not loaded;

**解决:**更改了 Qt 自带驱动中 libqsqlmysql.dylib 保存路径,install_name_tool -change /usr/local/mysql/lib/libmysqlclient.20.dylib /usr/local/Cellar/mysql/8.0.22_1/lib/libmysqlclient.21.dylib libqsqlmysql.dylib,Windows 中直接将 SQL 的驱动 libmysql.lib 复制粘贴到 C:\Qt\5.12.0\src\plugins\sqldrivers\mysql 即可。

尚未解决的问题:可能是全局静态变量 db 未赋初值的问题,从登录界面退出程序系统会报 L1brary quit unexpectedly。

程序从 Mac 移植到 Windows 上后界面大小不一致,加入判断屏幕分辨率改善。

开发环境(包括语言、平台、所使用数据库的名称以及版本号)

语言:C++

平台:MacOS 11.0, Qt 5.12.0, clang_64bit

Windows 10, Qt 5.12.0, MinGW_64_bit

数据库:华为云 GaussDB

ip: 139.9.119.34;

帐号:s2018303116;

密码:GaussDB@123;

数据库名:library_2018303116。

MySQL 版本号:8.0.18


http://www.ppmy.cn/news/1531281.html

相关文章

【专题】2024年中国白酒行业数字化转型研究报告合集PDF分享(附原数据表)

原文链接:https://tecdat.cn/?p37755 消费人群趋于年轻化,消费需求迈向健康化,消费场景与渠道走向多元化,这些因素共同驱动企业凭借数据能力来适应市场的变化。从消费市场来看,消费群体、需求、场景及渠道皆展现出与…

基于MaxScale搭建MariaDB读写分离集群的方法【2024年最新版】

1、什么是MaxScale MaxScale是MariaDB数据库的一个中间件,为MariaDB提供代理服务,主要可以实现读写分离和一定的负载均衡功能,其中读写分离可将读操作和写操作分离到不同的数据库服务器上,以提高系统的整体性能和扩展性&#xff…

RHCSA认证-Linux(RHel9)-Linux入门

文章目录 概要一、创建、查看和编辑⽂本1.1 输出重定向1.2 vim编辑器1.3 shell 变量1.5 获取帮助 二、管理本地用户和组2.1 描述用户2.2 切换用户和赋权2.3 用户管理2.4 用户组管理2.5 密码策略 三、控制文件访问3.1 列出文件和文件权限3.2 更改文件权限和拥有者3.3 控制默认权…

Docker实践与应用

引言 在现代软件开发中,Docker以其独特的容器化技术正在迅速改变传统的应用部署方式。Docker不仅提供了应用的便携性和一致性,还有效地解决了环境配置问题。本文将深入探讨Docker的安装、使用、最佳实践及其在实际项目中的应用,帮助开发者更…

前端项目如何使用思源字体

在前端项目中使用思源字体(微软字体商用收费如微软雅黑)可以通过以下几种方式实现: 1. 使用 CDN 引入字体 你可以通过公共 CDN 来引入思源字体,像 Google Fonts 或 Adobe Fonts 提供的思源字体服务。 步骤: 在你的…

assert 语句的主要用途是什么?

assert 语句在 Python 中用于调试目的,主要用于在代码中设置检查点,以确保程序中的某个条件为真。如果条件为假(即表达式的结果为 False),则 assert 会抛出一个 AssertionError 异常。虽然 assert 很有用,但…

URI和URL的区别

1: 将 URI 转换为 URL import java.net.URI; import java.net.URL;public class UriToUrlExample {public static void main(String[] args) {// 创建一个 URI 对象URI uri = new URI("http://example.com/path/to/resource");// 将 URI 转换为 URLtry {URL url = u…

在 Kubernetes 上部署 .NET 应用的完整指南:从容器化到自动化 CI/CD

在 Kubernetes 上部署 .NET 应用的完整指南 目录 引言.NET 应用的容器化Kubernetes 基础概念在 Kubernetes 上部署 .NET 应用高级特性:自动扩展与滚动更新持久化存储结合 CI/CD 实现自动化部署总结 1. 引言 随着微服务架构的流行,容器化技术已经成为应…