毕业设计:基于springboot夕阳红公寓管理系统的设计与实现(源码)
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) |
danyuan_types | 单元 | √ | int(11) |
fangke_name | 访客姓名 | √ | varchar(200) |
fangke_phone | 访客手机号 | √ | varchar(200) |
fangke_id_number | 访客身份证号 | √ | varchar(200) |
sex_types | 性别 | √ | int(11) |
fangke_photo | 健康码 | √ | varchar(200) |
fangke_content | 来访事由 | √ | text |
insert_time | 来访时间 | √ | timestamp |
create_time | 创建时间 | √ | timestamp |
表4.2 缴费表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | int(11) |
danyuan_types | 单元 | √ | int(11) |
shangpin_name | 缴费名称 | √ | varchar(200) |
jiaofei_time | 缴费月份 | √ | varchar(200) |
wuye_money | 物业费 | √ | decimal(10,2) |
fangzu_money | 房租费 | √ | decimal(10,2) |
zong_money | 总费用 | √ | decimal(10,2) |
jiaofei_types | 是否缴费 | √ | int(11) |
jiaofei_content | 备注 | √ | text |
insert_time | 添加时间 | √ | timestamp |
create_time | 创建时间 | √ | timestamp |
表4. 3 留言表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | int(11) |
zuke_id | 租客 | √ | int(11) |
liuyan_name | 留言标题 | √ | varchar(200) |
liuyan_text | 留言内容 | √ | text |
reply_text | 回复内容 | √ | text |
insert_time | 留言时间 | √ | timestamp |
update_time | 回复时间 | √ | timestamp |
create_time | 创建时间 | √ | timestamp |
表4. 4 管理员表
字段 | 注释 | 类型 | 空 |
|---|---|---|---|
id (主键) | 主键 | bigint(20) | × |
username | 用户名 | varchar(100) | × |
password | 密码 | varchar(100) | × |
role | 角色 | varchar(100) | √ |
addtime | 新增时间 | timestamp | × |
表4. 5 维修表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | int(11) |
zuke_id | 租客 | √ | int(11) |
weixiu_name | 维修名称 | √ | varchar(200) |
weixiu_types | 维修类型 | √ | int(11) |
weixiu_content | 申请详情 | √ | text |
insert_time | 申请时间 | √ | timestamp |
shifou_types | 是否维修 | √ | int(11) |
create_time | 创建时间 | √ | timestamp |
表4.6 行程轨迹表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | int(11) |
zuke_id | 用户 | √ | int(11) |
xingcheng_photo | 健康码 | √ | varchar(200) |
gonggao_name | 行程轨迹 | √ | varchar(200) |
xingcheng_content | 备注 | √ | text |
insert_time | 登记时间 | √ | timestamp |
create_time | 创建时间 | √ | timestamp |
表4. 7 租客表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | int(11) |
username | 账户 | √ | varchar(200) |
password | 密码 | √ | varchar(200) |
zuke_name | 租客姓名 | √ | varchar(200) |
zuke_phone | 租客手机号 | √ | varchar(200) |
zuke_id_number | 租客身份证号 | √ | varchar(200) |
zuke_email | 电子邮箱 | √ | varchar(200) |
zuke_photo | 租客头像 | √ | varchar(200) |
sex_types | 性别 | √ | int(11) |
danyuan_types | 单元号 | × | int(11) |
shiyong_types | 使用 | √ | int(11) |
new_money | 余额 | √ | decimal(10,2) |
create_time | 创建时间 | √ | timestamp |
表4. 8 公告信息表
字段 | 注释 | 空 | 类型 |
|---|---|---|---|
id (主键) | 主键 | × | int(11) |
gonggao_name | 公告名称 | √ | varchar(200) |
gonggao_photo | 公告图片 | √ | varchar(200) |
gonggao_types | 公告类型 | × | int(11) |
insert_time | 公告发布时间 | √ | timestamp |
gonggao_content | 公告详情 | √ | text |
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 维修管理界面
5.2.5 行程轨迹管理
图5.10 即为编码实现的行程轨迹管理界面,租客在该界面中对自己的行程轨迹信息进行登记,可以编辑,查询,删除个人行程轨迹信息。
图5.10 行程轨迹管理界面
