在上一篇文章里我们简单的说了一下图书管理系统的设计思路,这一篇文章我们将设计一下此系统的数据库.
一:前提条件:
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中使用数据库