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

相关文章

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

如何在 Spring Boot 中实现 FreeMarker 模板

《如何在SpringBoot中实现FreeMarker模板》FreeMarker是一种功能强大、轻量级的模板引擎,用于在Java应用中生成动态文本输出(如HTML、XML、邮件内容等),本文... 目录什么是 FreeMarker 模板?在 Spring Boot 中实现 FreeMarker 模板1. 环

SpringMVC 通过ajax 前后端数据交互的实现方法

《SpringMVC通过ajax前后端数据交互的实现方法》:本文主要介绍SpringMVC通过ajax前后端数据交互的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价... 在前端的开发过程中,经常在html页面通过AJAX进行前后端数据的交互,SpringMVC的controll

Java中的工具类命名方法

《Java中的工具类命名方法》:本文主要介绍Java中的工具类究竟如何命名,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java中的工具类究竟如何命名?先来几个例子几种命名方式的比较到底如何命名 ?总结Java中的工具类究竟如何命名?先来几个例子JD

Java Stream流使用案例深入详解

《JavaStream流使用案例深入详解》:本文主要介绍JavaStream流使用案例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录前言1. Lambda1.1 语法1.2 没参数只有一条语句或者多条语句1.3 一个参数只有一条语句或者多

Spring Security自定义身份认证的实现方法

《SpringSecurity自定义身份认证的实现方法》:本文主要介绍SpringSecurity自定义身份认证的实现方法,下面对SpringSecurity的这三种自定义身份认证进行详细讲解,... 目录1.内存身份认证(1)创建配置类(2)验证内存身份认证2.JDBC身份认证(1)数据准备 (2)配置依