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

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

一:前提条件:

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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏小二的折腾日记

面试总结-链接

https://blog.csdn.net/CCUTwangning/article/details/70153589 天下无难试之Redis面试题刁难大全 h...

691
来自专栏云计算教程系列

如何在Ubuntu 16.04上的三节点集群上部署CockroachDB

CockroachDB是一个开源的分布式SQL数据库,提供一致性、可伸缩性和生存性。

1592
来自专栏PHP在线

PHP输入流php://input介绍

在使用xml-rpc的时候,server端获取client数据,主要是通过php输入流input,而不是$_POST数组。所以,这里主要探讨php输入流php:...

4225
来自专栏张善友的专栏

Mongo Database 性能优化

SQL Server有工具进行数据库的优化,Mongo Database Profiler.不仅有,而且功能更强大。 MongoDB 自带 Profiler,可...

34110
来自专栏芋道源码1024

分布式事务 TCC-Transaction 源码分析 —— 事务恢复

1. 概述 本文分享 TCC 恢复。主要涉及如下二个 package 路径下的类: org.mengyun.tcctransaction.recover Rec...

3713
来自专栏Java编程技术

MySQL 中基于 XA 实现的分布式事务

Xa主要规定了RM与TM之间的交互,下面来看下XA规范中定义的RM 和 TM交互的接口:

1103
来自专栏沃趣科技

翻译系列第八弹: 高级知识ASM file extent map

原作者:Bane Radulovic 译者: 庄培培 审核: 魏兴华 DBGeeK社群联合出品 当ASM创建一个文件时(例如数据库实例要求创建一个数...

4575
来自专栏不止思考

架构师带你玩转分布式锁

当某个资源在多系统之间,具有共享性的时候,为了保证大家访问这个资源数据是一致的,那么就必须要求在同一时刻只能被一个客户端处理,不能并发的执行,否者就会出现同一时...

871
来自专栏FreeBuf

代码审计 | HDWiki v6.0最新版referer注入漏洞

近期在审计HDWiki 6.0最新版cms的时候发现由referer导致的sql注入问题。SQL注入我们知道是由于代码与数据没有严格区别限制分离而导致的问题,O...

1582
来自专栏张尧博客

su和sudo之间的区别以及如何在Linux中配置sudo

4826

扫码关注云+社区

领取腾讯云代金券