前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Python学习系列:使用pyqt5搭建简单图书管理系统(2)

Python学习系列:使用pyqt5搭建简单图书管理系统(2)

作者头像
云时之间
发布2018-12-14 17:14:17
1.8K1
发布2018-12-14 17:14:17
举报
文章被收录于专栏:云时之间云时之间

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

一:前提条件:

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中使用数据库

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018.11.17 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档