第4章 系统设计
系统的设计一切都是为了用户的使用,虽然用户使用过程中可能只是面对着浏览器进行各种操作,但是不代表着系统对于用户在浏览器上的操作不进行处理,所以说,设计一个系统需要考虑到方方面面。
4.1 功能结构设计
图4.1即为设计的管理员功能结构,管理员权限操作的功能包括对注册用户信息的管理,对宠物领养,宠物认领,教学视频,感谢信以及公告进行管理,审核宠物领养以及认领的信息。
图4.1 管理员功能结构
图4.2即为设计的用户功能结构,用户权限操作的功能包括申请领养宠物,申请认领宠物,查看申请的宠物领养或申请的宠物认领的审核状态,发布感谢信,查看或对教学视频进行收藏以及留言。
图4.2 用户功能结构
4.2 数据库设计
宠物领养系统运行中产生的数据需要按照提前设置的存储规则进行保存,而这个存储规则则是在数据库的设计中进行设置的。通常情况下,为了更好的配合系统运行,也要给用户带来良好的使用体验,设计一个很好的数据库是必须的,因为它能减少用户的等待时间,还可以对系统的请求在最短时间内进行响应。所以,对数据库设计时,需要花费一定的时间来分析系统对于数据存储的要求以及存储的具体数据,然后设计具体的存储规则,保证数据库能够对系统的各种数据请求进行及时回应,缩短数据处理时间,并在一定程度上降低数据冗余,节省存储空间。
4.2.1 数据库概念设计
实体-联系图还有一个名称即E-R图,是Entity Relationship Diagram各英文单词首字母的缩写,它这种概念模型通常用于对现实世界进行描述。同时它还是一种能够直观表达数据中实体,联系,属性的有效手段。绘制E-R图能够选择的工具也有很多,但是Office Visio 这款软件在E-R图的绘制上一般都是作为首选工具,因为它是基于可视化处理,使用它创建E-R图非常简单。使用基本的E-R图构成元素,比如椭圆,菱形,矩形,还有实线段来表达对应的信息,椭圆代表属性,即实体的特征,矩形代表实体,即数据库中的一个具体数据表,菱形代表实体中相互关系,实线段主要是完成椭圆,矩形,菱形的连接,基于这样的方式即可完成对本系统的E-R图进行完整绘制。
(1)图4.4即为宠物认领这个实体所拥有的属性值。
图4.4 宠物认领实体属性图
(2)图4.5即为用户这个实体所拥有的属性值。
图4.5 用户实体属性图
(3)图4.6即为宠物领养这个实体所拥有的属性值。
图4.6 宠物领养实体属性图
图4.7即为管理员这个实体所拥有的属性值。
图4.7 管理员实体属性图
图4.8即为上面介绍的实体中存在的联系。
图4.8 实体间关系E-R图
4.2.2 数据库物理设计
本小节主要任务即是根据上述内容进行数据存储结构的设计,也就是在数据库中设计存放本系统的数据的数据表,设计数据表时,需要对各个字段进行确定,通常来说,一个实体与一张数据表相对应,实体的属性就用来表示字段名称,不同的字段表示的数据类型以及取值都不相同,这里需要根据系统实际数据的情况进行设置,同时也需要在具体表中确定该表的主键,以及该表各个字段是否能够保持空等进行说明,设计完成一张数据表的结构之后,在保存时同样要命名,尽量选择英文名称进行命名并保存,方便今后系统对数据表进行数据存储访问时,在提高数据存储效率的同时,还不容易导致系统出错。接下来就对设计的数据表进行展示。
表4.1 宠物领养表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | int(11) |
chongwulingyang_name | 标题 | √ | varchar(200) |
chongwulingyang_types | 类型 | √ | int(11) |
chongwulingyang_photo | 宠物图片 | √ | varchar(200) |
jieshu_types | 是否被认领 | √ | int(11) |
chongwulingyang_content | 宠物详情 | √ | text |
create_time | 创建时间 | √ | timestamp |
表4.2 管理员表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | bigint(20) |
username | 用户名 | × | varchar(100) |
password | 密码 | × | varchar(100) |
role | 角色 | √ | varchar(100) |
addtime | 新增时间 | × | timestamp |
表4.3 宠物认领审核表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | int(11) |
chongwurenling_id | 宠物认领 | √ | int(11) |
yonghu_id | 认领用户 | √ | int(11) |
chongwurenlingshenhe_text | 认领凭据 | √ | text |
chongwurenlingshenhe_yesno_types | 申请状态 | √ | int(11) |
create_time | 创建时间 | √ | timestamp |
表4.4 宠物认领表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | int(11) |
chongwurenling_name | 标题 | √ | varchar(200) |
chongwulingyang_types | 类型 | √ | int(11) |
chongwurenling_photo | 宠物图片 | √ | varchar(200) |
yonghu_id | 发布用户 | √ | int(11) |
jieshu_types | 是否找到主人 | √ | int(11) |
chongwurenling_content | 宠物详情 | √ | text |
create_time | 创建时间 | √ | timestamp |
表4.5 宠物领养审核表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | int(11) |
chongwulingyang_id | 宠物领养 | √ | int(11) |
yonghu_id | 领养用户 | √ | int(11) |
chongwurenlingshenhe_text | 认领凭据 | √ | text |
chongwulingyangshenhe_yesno_types | 申请状态 | √ | int(11) |
create_time | 创建时间 | √ | timestamp |
表4.6 感谢信表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | int(11) |
ganxiexin_name | 标题 | √ | varchar(200) |
yonghu_id | 发布用户 | √ | int(11) |
ganxiexin_content | 内容 | √ | text |
create_time | 创建时间 | √ | timestamp |
表4.7 视频收藏表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | int(11) |
jiaoxueshipin_id | 视频 | √ | int(11) |
yonghu_id | 用户 | √ | int(11) |
jiaoxueshipin_collection_types | 类型 | √ | int(11) |
insert_time | 收藏时间 | √ | timestamp |
create_time | 创建时间 | √ | timestamp |
表4.8 视频留言表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | int(11) |
jiaoxueshipin_id | 视频 | √ | int(11) |
yonghu_id | 用户 | √ | int(11) |
jiaoxueshipin_liuyan_text | 留言内容 | √ | text |
reply_text | 回复内容 | √ | text |
insert_time | 留言时间 | √ | timestamp |
update_time | 回复时间 | √ | timestamp |
create_time | 创建时间 | √ | timestamp |
表4.9 教学视频表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | int(11) |
jiaoxueshipin_name | 视频标题 | √ | varchar(200) |
jiaoxueshipin_types | 视频类型 | √ | int(11) |
jiaoxueshipin_photo | 封面 | √ | varchar(200) |
jiaoxueshipin_video | 视频 | √ | varchar(200) |
zan_number | 赞 | √ | int(111) |
cai_number | 踩 | √ | int(111) |
jiaoxueshipin_content | 详情 | √ | text |
create_time | 创建时间 | √ | timestamp |
表4.10 公告表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | int(11) |
news_name | 公告名称 | √ | varchar(200) |
news_types | 公告类型 | √ | int(11) |
news_photo | 公告图片 | √ | varchar(200) |
insert_time | 公告时间 | √ | timestamp |
news_content | 公告详情 | √ | text |
create_time | 创建时间 | √ | timestamp |
表4.11 用户表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | int(11) |
username | 账户 | √ | varchar(200) |
password | 密码 | √ | varchar(200) |
yonghu_name | 用户姓名 | √ | varchar(200) |
sex_types | 性别 | √ | int(11) |
yonghu_id_number | 身份证号 | √ | varchar(200) |
yonghu_phone | 手机号 | √ | varchar(200) |
yonghu_address | 个人地址 | √ | varchar(200) |
yonghu_photo | 照片 | √ | varchar(200) |
create_time | 创建时间 | √ | timestamp |
第5章 系统实现
编程人员在搭建的开发环境中,运用编程技术实现本系统设计的各个操作权限的功能。在本节中,就展示部分操作权限的功能与界面。
5.1 管理员功能实现
5.1.1 宠物领养管理
图5.1 即为编码实现的宠物领养管理界面,管理员在该界面中发布需要领养的宠物的资料,可以对宠物领养的信息进行更改,查询,删除。
图5.1 宠物领养管理界面
5.1.2 宠物领养审核管理
图5.2 即为编码实现的宠物领养审核管理界面,管理员在该界面中对用户申请领养的宠物进行线上审核,管理员对宠物领养的信息审核通过之后,该宠物的领养状态就是被领养的状态了。
图5.2 宠物领养审核管理界面
5.1.3 宠物认领管理
图5.3 即为编码实现的宠物认领管理界面,管理员在该界面中发布宠物的认领信息,其中包括宠物的图片,宠物的类型等信息,管理员对宠物的认领信息也能更改,查询,删除。
图5.3 宠物认领管理界面
5.1.4 宠物认领审核管理
图5.4 即为编码实现的宠物认领审核管理界面,管理员在该界面中对用户申请认领的宠物信息进行线上审核,审核后的宠物认领信息只能进行查看和查询。
图5.4 宠物认领审核管理界面
5.1.5 教学视频管理
图5.5 即为编码实现的教学视频管理界面,管理员在该界面中主要是上传教学视频,对教学视频信息包括视频文件,视频标题等资料进行更改,查询,或删除,可以查看已发布教学视频的用户点赞数等信息。
图5.5 教学视频管理界面
5.2 用户功能实现
5.2.1 宠物领养
图5.6 即为编码实现的宠物领养界面,用户在该界面中查看宠物领养的介绍信息,只能对未被领养的宠物进行申请领养,已经被领养的宠物只能查看其介绍信息。
图5.6 宠物领养界面
5.2.2 宠物认领
图5.7 即为编码实现的宠物认领界面,用户在该界面中查看宠物认领信息,已经找到主人的宠物不支持认领。还没有找到主人的宠物才能进行申请认领。
图5.7 宠物认领界面
5.2.3 教学视频
图5.8 即为编码实现的教学视频界面,用户在该界面中主要就是播放教学视频,在教学视频下方发布留言,该教学视频也支持用户在当前页面进行收藏,方便下次查看。
图5.8 教学视频界面
5.2.4 感谢信管理
图5.9 即为编码实现的感谢信管理界面,用户在该界面中可以发布感谢信,对感谢信的内容进行更改,查询,删除。
图5.9 感谢信管理界面