java 雇员_Java学员作品-雇员管理系统

2023-10-13 13:50

本文主要是介绍java 雇员_Java学员作品-雇员管理系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.需求分析

该项目完成如下功能:

1. 管理员可以登录到管理界面

5c60653dba3a7b0b41b851003d6aa1b7.png

2. 可以对雇员进行增加

3. 可以对雇员进行修改

ae991a9317a4f08cd41a176c1a33a8dd.png

4. 可以查看雇员(分页显示)

5. 可以删除雇员

002f486a5ea0e305490df2b357a0c6c1.png

二.设计数据库

请注意:对于一个大型项目而言.我们建议表的字段名可以采用

表名_字段名

管理员表:

admin

create table admin(

id int primary key ,

name varchar(32) not null,

password varchar(128) not null);

雇员表 emp

create table emp(

id int primary key auto_increment,

name varchar(64) not null,

grade tinyint, /*1 表示1级工.. */

email varchar(64) not null,

salary float

)

表创建到mysql数据库

添加初始化数据

insert into emp (name,grade,email,salary)

values('shunping',1,'shunping@sohu.com',200);

insert into admin values(100,'admin',md5('admin'));

1. 代码阶段

准备素材(图片,静态页面,flash,文字...)..

要求:如果登录不成功,在login.php页面显示红色的提示信息.

在管理页面提供一个超链接,可以退出系统

① 如果完成不到数据库验证,就可以登录成功,如果不成功,给出提示.

② 要求到数据库去验证,该用户是否存在.

③ 在管理页面显示登录成功的人名字

思路: 通过跳转把用户名专递给 empManage.php页面

④ 在用户列表页面(empList.php)显示所有的用户信息

⑤ 考虑分页显示我们的用户信息.

思路:

在分页中有几个变量是必须的

5.1 $pageNow ->显示第几页 用户输入

5.2 $pageCount -> 共有几页 [在程序中算法 ]

5.3 $rowCount ->共有多少条记录 [这个数据库获取]

5.4 $pageSize ->每页显示几条记录 [程序员定义]

实例

说明

$pageNow=1

$rowCount=7

$pageSize=3

讨论 $pageCount怎样计算

//小算法

$pageNow=1

$rowCount=7

$pageSize=3

$pageCount=ceil($rowCount/$pageSize);

//刚好能整除

/*if($rowCount%$pageSize==0){

$pageCount=$rowCount/$pageSize;

}else{

$pageCount= ceil($rowCount/$pageSize);

}*/

?>

测试一下分页的效率 ,在实际开发中,数据量很大,因此,需要我们测试当数据量大时,是否可以满足用户需求.,模拟大量的数据 20w

mysql 自我复制

insert into emp (name,grade,email,salary) select name,grade,email,salary

from emp;

⑥ 网站结构的问题

从整个项目看,我们的页面中 loginProcesss.php 和 empList.php中有对数据库的操作,代码有重复

在empList.php 页面中有显示用户信息,还有分页逻辑 ,界面和业务逻辑混合,不好

说明一下我们的软件(网站),开发经过了三个阶段

model1 -> 分层(mv)->mvc模式

mdel1 基本概念是: 把界面和业务放在一个页面完成.

分层模式 基本概念是; 把界面和业务分开编写.->好处就是结构清晰,利于分工开发.

mvc 模式: 基本概念: 强制把数据的输入,数据的处理,数据的显示分开

u 使用分层模式来完成雇员信息分页的功能

思路:

1. 在什么文件中去封装我们的分页代码->EmpService.class.php

2. 通过分析我们知道为了完成分页我们的empList.php 文件需要两个重要的数据 一个是 $pageCount 第二个是 分页需要显示的数据

$res2

3. 代码

4. 我们要处理如果关闭资源的问题,问题很重要.

上机的任务:

框架图的用户登录,分页显示雇员信息,使用分层模式开完成.体会一下该模式的特点.,同时考虑实现 10页翻页的功能.

同时考虑实现 10页翻页的功能

思路的分析:

$page_whole=10;

$start=floor(($pageNow-1)/$page_whole)*$page_whole+1;

$index=$start;

//整体每10页向前翻

//如果当前pageNow在1-10页数,就没有向前翻动的超连接

if($pageNow>$page_whole){

echo " <<

";

}

//定$start 1---》10 floor((pageNow-1)/10)=0*10+1 11->20

floor((pageNow-1)/10)=1*10+1 21-30 floor((pageNow-1)/10)=2*10+1

for(;$start

echo "[$start]";

}

//整体每10页翻动

echo " >>

";

u 请大家考虑,目前我们为了完成分页,是写在EmpSerivice 类,我们能不能做一个通用的方法,可以适用于各种情况的分页?

u 如何做一个通用的分页模块(函数)

思路:

我设计一个FenyePage 类,该类可以封装我们分页需要的各种信息

class FenyePage{

public $pageSize=6;

public $res_array; //这是显示数据

public $rowCount; //这是从数据库中获取

public $pageNow; //用户指定的

public $pageCount; //这个是计算得到的

}

u 我增加一个新的功能,删除某个雇员

1. 我们使用传统的方法来完成,然后分析问题所在?

把删除用户的请求,提交给empList.php页面本身,因为empList.php页面目前可以接收两种请求,因此我们需要分别对待,最简单的方法就是设置一个标志位

flag

分析: 我们如果真的这样吧删除请求,直接交给empList.php, 这个页面好的结构会被坏,所以这个页面又会变得臃肿

这篇关于java 雇员_Java学员作品-雇员管理系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/203660

相关文章

idea maven编译报错Java heap space的解决方法

《ideamaven编译报错Javaheapspace的解决方法》这篇文章主要为大家详细介绍了ideamaven编译报错Javaheapspace的相关解决方法,文中的示例代码讲解详细,感兴趣的... 目录1.增加 Maven 编译的堆内存2. 增加 IntelliJ IDEA 的堆内存3. 优化 Mave

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

springboot filter实现请求响应全链路拦截

《springbootfilter实现请求响应全链路拦截》这篇文章主要为大家详细介绍了SpringBoot如何结合Filter同时拦截请求和响应,从而实现​​日志采集自动化,感兴趣的小伙伴可以跟随小... 目录一、为什么你需要这个过滤器?​​​二、核心实现:一个Filter搞定双向数据流​​​​三、完整代码

SpringBoot利用@Validated注解优雅实现参数校验

《SpringBoot利用@Validated注解优雅实现参数校验》在开发Web应用时,用户输入的合法性校验是保障系统稳定性的基础,​SpringBoot的@Validated注解提供了一种更优雅的解... 目录​一、为什么需要参数校验二、Validated 的核心用法​1. 基础校验2. php分组校验3

Java Predicate接口定义详解

《JavaPredicate接口定义详解》Predicate是Java中的一个函数式接口,它代表一个判断逻辑,接收一个输入参数,返回一个布尔值,:本文主要介绍JavaPredicate接口的定义... 目录Java Predicate接口Java lamda表达式 Predicate<T>、BiFuncti

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Spring Security方法级安全控制@PreAuthorize注解的灵活运用小结

《SpringSecurity方法级安全控制@PreAuthorize注解的灵活运用小结》本文将带着大家讲解@PreAuthorize注解的核心原理、SpEL表达式机制,并通过的示例代码演示如... 目录1. 前言2. @PreAuthorize 注解简介3. @PreAuthorize 核心原理解析拦截与

一文详解JavaScript中的fetch方法

《一文详解JavaScript中的fetch方法》fetch函数是一个用于在JavaScript中执行HTTP请求的现代API,它提供了一种更简洁、更强大的方式来处理网络请求,:本文主要介绍Jav... 目录前言什么是 fetch 方法基本语法简单的 GET 请求示例代码解释发送 POST 请求示例代码解释

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++