JAVA WEB 使用dao方式实现增加雇员、修改雇员信息,显示雇员图片等功能

本文主要是介绍JAVA WEB 使用dao方式实现增加雇员、修改雇员信息,显示雇员图片等功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

整个项目的目录架构如下:
在这里插入图片描述

废话不多说,直接上代码:
Emp.java

package dao;
import java.util.Date;import org.eclipse.jdt.internal.compiler.ast.ThisReference;import com.mysql.jdbc.Blob;public class Emp {private int empno;private String ename;private String job;private Date hiredate;private float sal;private float comm;private String image;public int getEmpno() {return empno;}public void setEmpno(int empno) {this.empno = empno;}public String getEname() {return ename;}public void setEname(String ename) {this.ename = ename;}public String getJob() {return job;}public void setJob(String job) {this.job = job;}public Date getHiredate() {return hiredate;}public void setHiredate(Date hiredate) {this.hiredate = hiredate;}public float getSal() {return sal;}public void setSal(float sal) {this.sal = sal;}public float getComm() {return comm;}public void setComm(float comm) {this.comm = comm;}public String getImage() {return image;}public void setImage(String image) {this.image=image;}}

DatabaseConnection.java

package dao;
import java.sql.Connection;
import java.sql.DriverManager;//定义数据库连接类
public class DatabaseConnection {public static final String DBDRIVER = "com.mysql.jdbc.Driver";public static final String DBURL = "jdbc:mysql://localhost:3306/demo";public static final String DBUSER = "root";public static final String DBPASS = "root";private Connection conn = null;public DatabaseConnection() throws Exception {Class.forName(DBDRIVER);conn = DriverManager.getConnection(DBURL, DBUSER, DBPASS);}public Connection getConnection() {return this.conn;}public void close() throws Exception {if (this.conn != null) {try {this.conn.close();} catch (Exception e) {throw e;}}}
}

IEmpDAO.java

package dao;
//定义数据库操作的接口import java.util.List;public interface IEmpDAO {public boolean doCreate(Emp emp) throws Exception;public List<Emp> findALL(String keyWord) throws Exception;public Emp findByid(int empno) throws Exception;public boolean doUpdate(Emp emp) throws Exception;}

EmpDAOImpl.java

package dao;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;public class EmpDAOImpl implements IEmpDAO {private Connection conn = null;private PreparedStatement pstmt = null;public EmpDAOImpl(Connection conn) {this.conn = conn;}public boolean doCreate(Emp emp) throws Exception {boolean flag = false;String sql = "insert into emp(empno,ename,job,hiredate,sal,comm,image) values(?,?,?,?,?,?,?)";this.pstmt = this.conn.prepareStatement(sql);this.pstmt.setInt(1, emp.getEmpno());this.pstmt.setString(2, emp.getEname());this.pstmt.setString(3, emp.getJob());this.pstmt.setDate(4, new java.sql.Date(emp.getHiredate().getTime()));this.pstmt.setFloat(5, emp.getSal());this.pstmt.setFloat(6, emp.getComm());this.pstmt.setString(7, emp.getImage());if (this.pstmt.executeUpdate() > 0) {flag = true;}this.pstmt.close();return flag;}public List<Emp> findALL(String keyWord) throws Exception {List<Emp> all = new ArrayList<Emp>();String sql = "select empno,ename,job,hiredate,sal,comm,image From emp where ename like ? or job like ?";this.pstmt=this.conn.prepareStatement(sql);this.pstmt.setString(1, "%" + keyWord + "%");this.pstmt.setString(2, "%" + keyWord + "%");ResultSet rs = this.pstmt.executeQuery();Emp emp = null;while (rs.next()) {emp = new Emp();emp.setEmpno(rs.getInt(1));emp.setEname(rs.getString(2));emp.setJob(rs.getString(3));emp.setHiredate(rs.getDate(4));emp.setSal(rs.getFloat(5));emp.setComm(rs.getFloat(6));emp.setImage(rs.getString(7));all.add(emp);}this.pstmt.close();return all;}public Emp findByid(int empno) throws Exception {Emp emp = null;String sql = "select empno,ename,job,hiredate,sal,comm,image from emp where empno=?";this.pstmt = this.conn.prepareStatement(sql);this.pstmt.setInt(1, empno);ResultSet rs = this.pstmt.executeQuery();if (rs.next()) {emp = new Emp();emp.setEmpno((rs.getInt(1)));emp.setEname(rs.getString(2));emp.setJob(rs.getString(3));emp.setHiredate(rs.getDate(4));emp.setSal(rs.getFloat(5));emp.setComm(rs.getFloat(6));emp.setImage(rs.getString(7));}this.pstmt.close();return emp;}public boolean doUpdate(Emp emp) throws Exception {boolean flag = false;String sql = "update emp set ename=?,job=?,hiredate=?,sal=?,comm=?,image=? where empno=?";this.pstmt = this.conn.prepareStatement(sql);this.pstmt.setString(1, emp.getEname());this.pstmt.setString(2, emp.getJob

这篇关于JAVA WEB 使用dao方式实现增加雇员、修改雇员信息,显示雇员图片等功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python实现AVIF图片与其他图片格式间的批量转换

《Python实现AVIF图片与其他图片格式间的批量转换》这篇文章主要为大家详细介绍了如何使用Pillow库实现AVIF与其他格式的相互转换,即将AVIF转换为常见的格式,比如JPG或PNG,需要的小... 目录环境配置1.将单个 AVIF 图片转换为 JPG 和 PNG2.批量转换目录下所有 AVIF 图

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Java Predicate接口定义详解

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

Pydantic中model_validator的实现

《Pydantic中model_validator的实现》本文主要介绍了Pydantic中model_validator的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录引言基础知识创建 Pydantic 模型使用 model_validator 装饰器高级用法mo

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

详解如何通过Python批量转换图片为PDF

《详解如何通过Python批量转换图片为PDF》:本文主要介绍如何基于Python+Tkinter开发的图片批量转PDF工具,可以支持批量添加图片,拖拽等操作,感兴趣的小伙伴可以参考一下... 目录1. 概述2. 功能亮点2.1 主要功能2.2 界面设计3. 使用指南3.1 运行环境3.2 使用步骤4. 核

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

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

AJAX请求上传下载进度监控实现方式

《AJAX请求上传下载进度监控实现方式》在日常Web开发中,AJAX(AsynchronousJavaScriptandXML)被广泛用于异步请求数据,而无需刷新整个页面,:本文主要介绍AJAX请... 目录1. 前言2. 基于XMLHttpRequest的进度监控2.1 基础版文件上传监控2.2 增强版多

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

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

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