基于SpringBoot+Vue的乡政府管理系统(源码+部署说明+演示视频+源码介绍)(1)https://developer.aliyun.com/article/1558392
4.3.2 数据库物理设计
作为程序后台的支持,本数据库也需要设计数据存储的结构。而数据存储结构的设计就包括了数据表结构的设计和创建。数据表结构包括了字段,数据类型,还有字段的取值范围等信息。而E-R模型中的实体就是一张表,实体的特征就可以作为该表中的字段,根据本程序信息存储要求,设计每个字段需要的类型,还有该字段的取值范围等。每当设计完成一张数据表,就需要及时保存在数据库里面,并对该设计的数据表准确命名,要求设置的数据表的名称尽量不要是中文,而且要方便记忆。因为在程序编码阶段,通过SQL语句可以把程序里面的数据写入在各个数据表里面,而这个环节需要使用到数据表的名称。如果数据表名称是中文的话,可能会乱码并影响程序运行。下面就以表格形式展示设计的结果。
表4.1字典表表
序号 |
列名 |
数据类型 |
说明 |
允许空 |
1 |
Id |
Int |
id |
否 |
2 |
dic_code |
String |
字段 |
是 |
3 |
dic_name |
String |
字段名 |
是 |
4 |
code_index |
Integer |
编码 |
是 |
5 |
index_name |
String |
编码名字 |
是 |
6 |
super_id |
Integer |
父字段id |
是 |
7 |
beizhu |
String |
备注 |
是 |
8 |
create_time |
Date |
创建时间 |
是 |
表4.2论坛表
序号 |
列名 |
数据类型 |
说明 |
允许空 |
1 |
Id |
Int |
id |
否 |
2 |
forum_name |
String |
帖子标题 |
是 |
3 |
yonghu_id |
Integer |
用户 |
是 |
4 |
users_id |
Integer |
管理员 |
是 |
5 |
forum_content |
String |
发布内容 |
是 |
6 |
super_ids |
Integer |
父id |
是 |
7 |
forum_state_types |
Integer |
帖子状态 |
是 |
8 |
insert_time |
Date |
发帖时间 |
是 |
9 |
update_time |
Date |
修改时间 |
是 |
10 |
create_time |
Date |
创建时间 |
是 |
表4.3活动信息表
序号 |
列名 |
数据类型 |
说明 |
允许空 |
1 |
Id |
Int |
id |
否 |
2 |
huodong_name |
String |
活动标题 |
是 |
3 |
huodong_types |
Integer |
活动类型 |
是 |
4 |
huodong_photo |
String |
活动封面 |
是 |
5 |
huodong_date |
String |
活动时间 |
是 |
6 |
huodong_content |
String |
活动详情 |
是 |
7 |
create_time |
Date |
创建时间 |
是 |
表4.4活动报名表
序号 |
列名 |
数据类型 |
说明 |
允许空 |
1 |
Id |
Int |
id |
否 |
2 |
huodong_id |
Integer |
活动 |
是 |
3 |
yonghu_id |
Integer |
用户 |
是 |
4 |
huodong_order_yesno_types |
Integer |
审核状态 |
是 |
5 |
huodong_order_yesno_text |
String |
审核结果 |
是 |
6 |
insert_time |
Date |
报名时间 |
是 |
7 |
create_time |
Date |
创建时间 |
是 |
表4.5家庭成员流动表
序号 |
列名 |
数据类型 |
说明 |
允许空 |
1 |
Id |
Int |
id |
否 |
2 |
yonghu_id |
Integer |
用户 |
是 |
3 |
jiatingchengyuan_name |
String |
外出人员名称 |
是 |
4 |
jiatingchengyuan_phone |
String |
外出人员联系方式 |
是 |
5 |
jiatingchengyuan_address |
String |
外出地址 |
是 |
6 |
jiatingchengyuan_date |
String |
外出时间 |
是 |
7 |
jiatingchengyuan_text |
String |
外出详情 |
是 |
8 |
insert_time |
Date |
添加时间 |
是 |
9 |
create_time |
Date |
创建时间 |
是 |
表4.6留言版表
序号 |
列名 |
数据类型 |
说明 |
允许空 |
1 |
Id |
Int |
id |
否 |
2 |
yonghu_id |
Integer |
用户 |
是 |
3 |
liuyan_name |
String |
留言标题 |
是 |
4 |
liuyan_text |
String |
留言内容 |
是 |
5 |
insert_time |
Date |
留言时间 |
是 |
6 |
reply_text |
String |
回复内容 |
是 |
7 |
update_time |
Date |
回复时间 |
是 |
8 |
create_time |
Date |
创建时间 |
是 |
表4.7新闻动态表
序号 |
列名 |
数据类型 |
说明 |
允许空 |
1 |
Id |
Int |
id |
否 |
2 |
news_name |
String |
新闻标题 |
是 |
3 |
news_types |
Integer |
新闻类型 |
是 |
4 |
news_photo |
String |
新闻图片 |
是 |
5 |
insert_time |
Date |
添加时间 |
是 |
6 |
news_content |
String |
新闻详情 |
是 |
7 |
create_time |
Date |
创建时间 |
是 |
表4.8用户表
序号 |
列名 |
数据类型 |
说明 |
允许空 |
1 |
Id |
Int |
id |
否 |
2 |
yonghu_name |
String |
用户姓名 |
是 |
3 |
yonghu_photo |
String |
头像 |
是 |
4 |
yonghu_phone |
String |
手机号 |
是 |
5 |
yonghu_email |
String |
电子邮箱 |
是 |
6 |
yonghu_types |
Integer |
家庭 |
是 |
7 |
yonghu_delete |
Integer |
假删 |
是 |
8 |
create_time |
Date |
创建时间 |
是 |
表4.9资料上传表
序号 |
列名 |
数据类型 |
说明 |
允许空 |
1 |
Id |
Int |
id |
否 |
2 |
ziliaoshangchuan_name |
String |
资料名称 |
是 |
3 |
ziliaoshangchuan_types |
Integer |
资料类型 |
是 |
4 |
ziliaoshangchuan_file |
String |
资料 |
是 |
5 |
insert_time |
Date |
添加时间 |
是 |
6 |
ziliaoshangchuan_content |
String |
资料详情 |
是 |
7 |
ziliaoshangchuan_yesno_types |
Integer |
审核状态 |
是 |
8 |
ziliaoshangchuan_yesno_text |
String |
审核结果 |
是 |
9 |
create_time |
Date |
创建时间 |
是 |
表4.10用户表表
序号 |
列名 |
数据类型 |
说明 |
允许空 |
1 |
Id |
Int |
id |
否 |
2 |
username |
String |
用户名 |
是 |
3 |
password |
String |
密码 |
是 |
4 |
role |
String |
角色 |
是 |
5 |
addtime |
Date |
新增时间 |
是 |
第5章系统实现
这个环节需要使用前面的设计方案,包括对系统模块的设计,还有对程序后台的数据支持的数据库的设计等。不过这部分内容还是强调系统编码人员的开发能力,要把前面设计的内容通过编码的形式以一个完整的,可以运行的系统呈现出来。
功能模块的实现
5.1用户信息管理
如图5.1显示的就是用户信息管理页面,此页面提供给管理员的功能有:用户信息的查询管理,可以删除用户信息、修改用户信息、新增用户信息,
还进行了对用户名称的模糊查询的条件
图5.1 用户信息管理页面
5.2 活动信息管理
如图5.2显示的就是活动信息管理页面,此页面提供给管理员的功能有:查看已发布的活动信息数据,修改活动信息,活动信息作废,即可删除,还进行了对活动信息名称的模糊查询活动信息信息的类型查询等等一些条件。
图5.2 活动信息管理页面
5.3新闻类型管理
如图5.3显示的就是新闻类型管理页面,此页面提供给管理员的功能有:根据新闻类型进行条件查询,还可以对新闻类型进行新增、修改、查询操作等等。
图5.3 新闻类型管理页面
5.1新闻动态管理
如图5.4显示的就是新闻动态管理页面,此页面提供给管理员的功能有:根据新闻动态进行新增、修改、查询操作等等。
图5.4 新闻动态管理页面
第6章 系统测试
尽管系统在编码过程中,程序的编制人员也会对编程的功能模块进行逐个测试,但还是避免不了已经组合完成的系统整体没有错误。很多时候,面对功能繁多,逻辑复杂的系统时,系统的测试就需要不同人来测试,并设计一些故障来检验系统的应对能力,以及发现很多系统内部的潜在问题。并通过寻求解决办法去完善系统,确保系统质量。
6.1 系统测试方法
根据系统的测试流程,划分的系统测试方法有单元测试,集成测试,系统测试,验收测试。接下来就开始描述这些内容。
单元测试:这个测试环节在编码中用得最多,主要是编程人员进行的,通常对编码实现的各个子模块当成一个单元完成测试,主要基于代码的层面去发现问题,所以它也是白盒测试中的一种。
集成测试:这个环节进行的前提是,已经把系统的各个子模块进行了组合,然后把组合的完整系统进行测试,检验组成目标系统的各个子模块是否具备兼容性,还有目标系统是否根据预期目标正常运行。
系统测试:这个环节用到了黑盒测试,主要是检验系统的功能。并确定目标系统的各个功能是否运行正常。
验收测试:这个环节需要用户参与,让用户在系统操作界面上通过对不同数据的输入,检测系统的输出结果,以此检验目标系统与用户需求之间存在的差异程度。存在的差异越小,就代表着越符合用户的期望。
6.2 功能测试
乡政府管理系统的目标用户最终面向的是系统的功能,所以检验本系统的功能也是一项重要任务,只有该系统的功能都能保证正常使用,才会吸引更多的用户来使用。
6.2.1 登录功能测试
本系统在编码时,提前在登录模块编写了安全验证规则,通过判断访问者提供的数据,引导符合要求的用户进入指定页面。测试表如下。错误的数据输入,在本系统中会得到及时的反馈提示。
表6.1 登录功能测试表
功能 |
录入的数据 |
预期结果 |
实际结果 |
结论 |
管理员登录 |
用户名:空 密码:空 |
提示请填写用户名 |
提示请填写用户名 |
通过测试 |
管理员登录 |
用户名:guanliyuan 密码:空 |
提示请填写密码 |
提示请填写密码 |
通过测试 |
管理员登录 |
用户名:guanliyuan 密码:gly |
提示用户名密码不匹配 |
提示用户名密码不匹配 |
通过测试 |
管理员登录 |
用户名:guanliyuan 密码:guanliyuan |
提示登录成功,并跳转到功能操作区 |
提示登录成功,并跳转到功能操作区 |
通过测试 |
6.3 测试结果分析
通过测试,可以发现乡政府管理系统具备完善的功能,同时具备易操作性和易维护性的特点,在系统安全性上也有比较健全的数据保护机制。至此,乡政府管理系统可以投入使用。