博主介绍:👉全网个人号和企业号粉丝40W+,每年辅导几千名大学生较好的完成毕业设计,专注计算机软件领域的项目研发,不断的进行新技术的项目实战👈
⭐️热门专栏推荐订阅⭐️ 订阅收藏起来,防止下次找不到🔎百套Python实战项目持续更新中~
有需求的各位可以先收藏起来,还有大家在毕设选题,开题报告有疑惑的都可以找我,给你参考意见,帮你做好开题答辩❤️文末获取源码联系、提供项目参考文档❤️ ⚠️一定要先收藏⚠️
4 系统设计
系统在设计的过程中,必然要遵循一定的原则才可以,胡乱设计是不可取的。首先用户在使用过程中,能够直观感受到功能操作的便利性,符合正常思维逻辑的操作,这才是系统好用的一个开端,给使用者第一印象就是这个系统设计的相当不错。
4.1 系统设计原则
系统遵循设计原则进行开发,会有很多可以预料到的好处,只要遵循了设计原则,那么开发出来的系统必然是有质量保证的。
首先第一条原则就是安全性原则:程序必须设定角色管理,不同的角色有不同的功能模块,不同的角色登录都需要输入相对应的账号和密码,否则不允许进行操作相对应的权限。每个用户登录只能修改自己的密码,不需要对别的账号进行密码或者其他资料的修改,否则就违背了安全性原则的设定。
其次第二条原则就是易用性原则:符合安全性只是功能的符合,不代表操作就符合,所以要设定易用性原则。易用性原则就是规定程序符合操作流程,正常人的思维定向为基础,在不违背程序运行逻辑定义的情况下,必须使用简单,操作规范,让每个用户使用起来都能看到页面,就能感知功能模块的作用,短时间的就能使用程序,达到易用效果。
再次第三条原则就是实用性原则:实用性代表着花里胡哨的功能必须抛弃,尽量符合数据处理的简洁性,不仅需要这样进行设定,还需要有预知性,系统后期可能会出现的功能模块尽量要解耦,与程序设定要模块化体现,这样才能达到扩展性。
第四条原则就是准确性原则:准确性原则的唯一定义就是准确,包含数据输入格式的准确,数据处理的准确,以及数据存储的准确。程序里面关于数据准确才有存在的意义,如果一堆不相干的数据存在是没有任何用处的,甚至会产生各种问题,所以必须要保证数据的准确性。
第五条原则是易维护原则:易维护代表着程序运行必须是可控的状态,如果不可控出现各种问题,那么所有的工作都是空谈。程序开发中对于各种程序判定异常,必须有统一的处理模式,异常是程序开发中不可避免的,但是可以对出现的异常进行抛出,有助于程序异常处理的复盘,只要每个异常都能定位准确,那么代表程序设计是趋于完美的,维护起来会更加的方便,只要有助于程序维护的都必须给予支持。
4.2 功能模块设计
对管理员具体功能的设计结果将以图4.1所示的管理员功能结构图来进行体现。管理员对于教学实习日志操作的功能包括审核用户评价商品的信息,查看商品评价统计报表,对商品,商品分类,订单等信息进行管理。
图4.1 管理员功能结构图
对用户具体功能的设计结果将以图4.2所示的用户功能结构图来进行体现。用户对于教学实习日志操作的功能包括在前台购买商品,咨询收藏,对个人收货地址以及订单,收藏的实习广场进行管理。
4.3 数据库设计
用户通过系统的功能操作来进行数据交互,包括数据的添加,数据的更新,数据的删除,数据的查询等基本功能操作,表面上虽然是操作系统界面提供的功能,但是实际上系统的这些数据是在数据库当中进行访问与操作的。目前市场上可供选择的存储数据的数据库有很多,除了简单版的Access之外,还有SQL Server,DB2,Informix,MySQL等关系型数据库可供选择,由于关系型数据库具有固定的表结构,以及对数据一致性要求比较强,所以相比没有固定表结构以及具有灵活的数据格式的非关系型数据库而言,在程序配套数据库的选择中,关系型数据库的使用率更高。本系统选择MySQL来存放数据,其相关理论以及技术在经过了很长时间的发展之后,变得非常成熟,各大网络平台都公开分享其开发源码,而且其对计算机的配置要求很低,不需要过多内存进行安装,很符合本系统对于数据库的选择要求。
4.3.1 数据库E-R图
本节需要对系统中存放在数据库中的数据进行充分分析,对数据的实体,实体特征,联系等进行确定,然后通过概念模型的表示方法即E-R图进行表达,在E-R图绘制工具中,选择椭圆,菱形框,矩形等形状表达实体属性,实体间联系,实体这些信息,使用实线段将这些形状进行连接即可。初步完成E-R图之后,需要进行检查,及时进行有误数据的更改,删除实体间存在的冗余联系,删除E-R图中冗余的数据,最终要展示一个内容准确的E-R图。
4.3.2 数据库表结构
在指定的数据库里面对数据表进行创建命名,然后设计各个数据表的存储结构,需要对该数据库的操作非常熟悉,并且还需要学习并掌握一定的数据表设计方面的知识,比如数据命名,作为系统的开发人员,为了避免程序运行产生乱码现象以及为了确保系统的正常运行,在对数据表进行命名时,一般都是采用英文名称,同时在对数据表的字段进行编辑时,也是采用英文的方式进行,为了方便今后对数据表的设计内容进行更改或查看,对一些比较重要的字段都会进行中文备注,或者是使用中文进行字段描述。设计期间,也需要对各个字段选择合适的数据类型以及设置匹配的取值范围,当一张数据表设计完成之后,还要对该表的主键进行标注,就是为了确保该数据表的唯一性与独立性。
表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 | jinxui_name | String | 标题 | 是 |
3 | jinxui_uuid_number | String | 编号 | 是 |
4 | jinxui_photo | String | 进修图片 | 是 |
5 | jinxui_types | Integer | 进修类型 | 是 |
6 | jinxui_video | String | 进修视频 | 是 |
7 | jinxui_content | String | 进修内容 | 是 |
8 | jinxui_file | String | 下载 | 是 |
9 | fabu_time | Date | 发布时间 | 是 |
10 | jinxui_delete | Integer | 逻辑删除 | 是 |
11 | insert_time | Date | 录入时间 | 是 |
12 | create_time | Date | 创建时间 | 是 |
表4.3进修留言表
序号 | 列名 | 数据类型 | 说明 | 允许空 |
1 | Id | Int | id | 否 |
2 | jinxui_id | Integer | 进修 | 是 |
3 | yonghu_id | Integer | 用户 | 是 |
4 | jinxui_liuyan_text | String | 留言内容 | 是 |
5 | insert_time | Date | 留言时间 | 是 |
6 | reply_text | String | 回复内容 | 是 |
7 | update_time | Date | 回复时间 | 是 |
8 | create_time | Date | 创建时间 | 是 |
表4.4老师表
序号 | 列名 | 数据类型 | 说明 | 允许空 |
1 | Id | Int | id | 否 |
2 | laoshi_name | String | 老师姓名 | 是 |
3 | laoshi_phone | String | 老师手机号 | 是 |
4 | laoshi_id_number | String | 老师身份证号 | 是 |
5 | laoshi_photo | String | 老师头像 | 是 |
6 | laoshi_email | String | 电子邮箱 | 是 |
7 | create_time | Date | 创建时间 | 是 |
表4.5实习广场表
序号 | 列名 | 数据类型 | 说明 | 允许空 |
1 | Id | Int | id | 否 |
2 | rizhi_name | String | 标题 | 是 |
3 | rizhi_uuid_number | String | 编号 | 是 |
4 | rizhi_photo | String | 日志图片 | 是 |
5 | rizhi_types | Integer | 日志类型 | 是 |
6 | rizhi_video | String | 日志视频 | 是 |
7 | rizhi_content | String | 日志内容 | 是 |
8 | fabu_time | Date | 发布时间 | 是 |
9 | zan_number | Integer | 赞 | 是 |
10 | cai_number | Integer | 踩 | 是 |
11 | rizhi_delete | Integer | 逻辑删除 | 是 |
12 | insert_time | Date | 录入时间 | 是 |
13 | create_time | Date | 创建时间 | 是 |
表4.6日志收藏表
序号 | 列名 | 数据类型 | 说明 | 允许空 |
1 | Id | Int | id | 否 |
2 | rizhi_id | Integer | 日志 | 是 |
3 | yonghu_id | Integer | 用户 | 是 |
4 | rizhi_collection_types | Integer | 类型 | 是 |
5 | insert_time | Date | 收藏时间 | 是 |
6 | create_time | Date | 创建时间 | 是 |
表4.7日志留言表
序号 | 列名 | 数据类型 | 说明 | 允许空 |
1 | Id | Int | id | 否 |
2 | rizhi_id | Integer | 日志 | 是 |
3 | yonghu_id | Integer | 用户 | 是 |
4 | rizhi_liuyan_text | String | 留言内容 | 是 |
5 | insert_time | Date | 留言时间 | 是 |
6 | reply_text | String | 回复内容 | 是 |
7 | update_time | Date | 回复时间 | 是 |
8 | create_time | Date | 创建时间 | 是 |
表4.8实践技术表
序号 | 列名 | 数据类型 | 说明 | 允许空 |
1 | Id | Int | id | 否 |
2 | shijian_name | String | 标题 | 是 |
3 | shijian_uuid_number | String | 编号 | 是 |
4 | shijian_photo | String | 实践技术图片 | 是 |
5 | shijian_types | Integer | 实践技术类型 | 是 |
6 | shijian_video | String | 实践技术视频 | 是 |
7 | shijian_content | String | 实践技术内容 | 是 |
8 | shijian_file | String | 下载 | 是 |
9 | fabu_time | Date | 发布时间 | 是 |
10 | shijian_delete | Integer | 逻辑删除 | 是 |
11 | insert_time | Date | 录入时间 | 是 |
12 | create_time | Date | 创建时间 | 是 |
表4.9疑问表
序号 | 列名 | 数据类型 | 说明 | 允许空 |
1 | Id | Int | id | 否 |
2 | yonghu_id | Integer | 用户 | 是 |
3 | laoshi_id | Integer | 老师 | 是 |
4 | yiwen_name | String | 主题 | 是 |
5 | yiwen_text | String | 疑问内容 | 是 |
6 | yiwen_file | String | 附件 | 是 |
7 | insert_time | Date | 疑问时间 | 是 |
8 | yiwen_types | Integer | 疑问类型 | 是 |
9 | yiwen_zhuangtai_types | Integer | 疑问状态 | 是 |
10 | reply_text | String | 回复内容 | 是 |
11 | update_time | Date | 回复时间 | 是 |
12 | create_time | Date | 创建时间 | 是 |
表4.10用户表
序号 | 列名 | 数据类型 | 说明 | 允许空 |
1 | Id | Int | id | 否 |
2 | yonghu_name | String | 用户姓名 | 是 |
3 | yonghu_phone | String | 用户手机号 | 是 |
4 | yonghu_id_number | String | 用户身份证号 | 是 |
5 | yonghu_photo | String | 用户头像 | 是 |
6 | yonghu_email | String | 电子邮箱 | 是 |
7 | create_time | Date | 创建时间 | 是 |
表4.11管理员表
序号 | 列名 | 数据类型 | 说明 | 允许空 |
1 | Id | Int | id | 否 |
2 | username | String | 用户名 | 是 |
3 | password | String | 密码 | 是 |
4 | role | String | 角色 | 是 |
5 | addtime | Date | 新增时间 | 是 |
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 实践技术管理界面
源码获取
大家点赞、收藏、关注 ,让更多需要的同学看到
不同开发语言专栏推荐订阅:
👇下方有我的微信名片👇