计算机系统应用教程网站

网站首页 > 技术文章 正文

手把手带你学Python:使用pyqt5搭建简单图书管理系统(2)

btikc 2024-10-20 05:03:39 技术文章 8 ℃ 0 评论

在上一篇文章里我们简单的说了一下图书管理系统的设计思路,这一篇文章我们将设计一下此系统的数据库.

一:前提条件:

1:文章中使用的数据库为sqlite

2:数据库管理软件:SqliteStudio

2:开发语言为Python

3:开发IDE为pycharm

二:图书管理系统的数据库设计

此数据库所设计的表我建了四个,当然实际系统比此复杂多,此数据库的结构如下所示:

具体到每个表:

1:BuyBook表

这个表的主要内容是我们作为管理方所购买的一些数据的信息,其中包含书籍ID,购买时间,借出还是没有借出,以及数量.

(MessageId,Time,BuyOrDrop,Number);

主键设置为MessageId,其中MessageId不为空,具体参数如下所示:

2:Message表

Message表是对书籍的本身信息的管理,其中包括书籍姓名,书籍ID,作者,分类,出版社,出版时间,总数量,可以借阅数量,借阅数量.

Message(BookName,BookId,Auth,Class,Publisher,

PublishTime,NumStorage,NumCanBorrow,NumBorrowed)

3:User

User表存储的是用户的账户信息和系统的管理员账户信息,一般情况下表中表示的是账户,姓名,密码,以及借书时间和借书数量等,这里的密码采用了MD5的加密工具,我们应该分析出管理员只有删除账户和重置用户信息的权利,密码应该对管理员是不可见的.

User(UserId,Name,Password,IsAdmin,TimeBorrowBook,NumBorrowBook)

4:User_Message

最后的User_Message表所表达的是用户借书的信息,其中包括了(UserId,MessageId,BorrowTime,ReturnTime,BorrwoState)这些信息,具体参数如下图所示:

三:pyqt5使用数据库

这部分介绍摘自网络的一位博主的文章,文末给出了文章地址,在此表示谢意

Qt平台对SQL编程有着良好的支持,PyQt5也一并继承了过来。在PyQt5中,QtSql子模块提供对SQL数据库的支持:

从上图我们可以发现,QtSQL模块中包含了很多个类,这些类归总起来主要包含三大部分:

1:驱动层:

用于提供特定数据库与SQL API接口之间的低级连接功能;其中包括QSqlDriver、QSqlDriverCreatorBase、QSqlResult;

2:SQL API层

用于提供对数据库的访问。通常来说,我们会使用QSqlDatabase建立数据库连接,使用QSqlQuery等类实现数据库的交互(执行SQL语句)。此外还有QSqlError、QSqlField、QSqlIndex、QSqlRecord等类。

3:用户界面操作层

用于将数据库操作的数据链接到PyQt相应的数据小部件,将数据和操作展示在Qt界面中。这些类包括:QSqlQueryModel、QSqlTableModel等。

在这些类中,每个类都有自己特定的用途,其中:

QSQL:包含整个Qt SQL模块中使用的各种标识符

QSqlDatabase:处理与数据库的连接

QSqlDriver:用于访问特定SQL数据库的抽象基类

QSqlDriverCreator:模板类,为特定驱动程序类型提供SQL驱动程序工厂

QSqlDriverCreatorBase:SQL驱动程序工厂的基类

QSqlError:SQL数据库错误信息

QSqlField:处理SQL数据库表和视图中的字段

QSqlIndex:用于操作和描述数据库索引的函数

QSqlQuery:执行和操作SQL语句的方法

QSqlQueryModel:SQL结果集的只读数据模型

QSqlRecord:封装数据库记录

QSqlRelationalTableModel:具有外键支持的单个数据库表的可编辑数据模型

QSqlResult:用于从特定SQL数据库访问数据的抽象接口

QSqlTableModel:单个数据库表的可编辑数据模型

在实际的PyQt编程中,我们很少使用驱动层的类,多通过API层的来建立数据库连接、进行数据库查询等,然后通过用户界面操作层的类将数据结果显示在图形界面中。下面我们就来简单使用一下。

在本系统中,我们以用户登录为例,表示一下如何连接数据库:

上述操作我们首先创建了一个数据库连接,然后打开我们定义的数据库,后续使用QSqlQuery语句输入SQL命令即可,最后关闭数据库,这些内容比较容易,在此就不再赘述,如有不理解,可以与我私下交流.

在后续的文章中,因为大量涉及代码与界面布局,我只会说一下大体思路,一些细节部分具体讨论,也希望和大家多多交流.

四:附录

引用资料:Python GUI教程(十四):在PyQt5中使用数据库

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表