springMVC实现增删改查
首先需要准备好一张数据库表我这里用emp这张表:具体代码:
/*
SQLyog 企业版 - MySQL GUI v8.14
MySQL - 5.1.73-community
*********************************************************************
*/
/*!40101 SET NAMES utf8 */; create table `emp` (
`empno` double ,
`ename` varchar (60),
`job` varchar (60),
`mgr` double ,
`hiredate` varchar (60),
`sal` float ,
`comm` float ,
`deptno` double
);
insert into `emp` (`empno`, `ename`, `job`, `mgr`, `hiredate`, `sal`, `comm`, `deptno`) values('','SMITH','CLERK','','2018-10-28 10:22:37','','0.565','');
insert into `emp` (`empno`, `ename`, `job`, `mgr`, `hiredate`, `sal`, `comm`, `deptno`) values('','Allen','SALESMAN','','2018-10-28 10:22:37','','','');
insert into `emp` (`empno`, `ename`, `job`, `mgr`, `hiredate`, `sal`, `comm`, `deptno`) values('','Ward','SALESMAN','','2018-10-28 10:22:37','','','');
insert into `emp` (`empno`, `ename`, `job`, `mgr`, `hiredate`, `sal`, `comm`, `deptno`) values('','JONES','MANAGER','','2018-10-28 10:22:37','','','');
insert into `emp` (`empno`, `ename`, `job`, `mgr`, `hiredate`, `sal`, `comm`, `deptno`) values('','MARTIN','SALESMAN','','2018-10-28 10:22:37','','','');
insert into `emp` (`empno`, `ename`, `job`, `mgr`, `hiredate`, `sal`, `comm`, `deptno`) values('','CLARK','MANAGER','','2018-10-28 10:22:37','',NULL,'');
insert into `emp` (`empno`, `ename`, `job`, `mgr`, `hiredate`, `sal`, `comm`, `deptno`) values('','SCOTT','ANALYST','','2018-10-28 10:22:38','',NULL,'');
insert into `emp` (`empno`, `ename`, `job`, `mgr`, `hiredate`, `sal`, `comm`, `deptno`) values('','KING','PRESIDENT',NULL,'2018-10-28 10:22:38','',NULL,'');
insert into `emp` (`empno`, `ename`, `job`, `mgr`, `hiredate`, `sal`, `comm`, `deptno`) values('','TURNER','SALESMAN','','2018-10-28 10:22:38','','','');
insert into `emp` (`empno`, `ename`, `job`, `mgr`, `hiredate`, `sal`, `comm`, `deptno`) values('','ADAMS','CLERK','','2018-10-28 10:22:38','',NULL,'');
insert into `emp` (`empno`, `ename`, `job`, `mgr`, `hiredate`, `sal`, `comm`, `deptno`) values('','FORD','ANALYST','','2018-10-28 10:22:38','',NULL,'');
然后开始我们的增删改查工作:
第一步:建立一个Maven项目,我们这里命名为"lianxicrud",然后配置pom.xml:需要的jar包有:jstl,javax.servlet-api,spring-web,spring-webmvc,
spring-jdbc,mysql
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>web01</groupId>
<artifactId>lianxicrud</artifactId>
<packaging>war</packaging>
<version>0.0.1-SNAPSHOT</version>
<name>lianxicrud Maven Webapp</name>
<url>http://maven.apache.org</url>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<!-- https://mvnrepository.com/artifact/javax.servlet/jstl -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.1</version>
<scope>provided</scope>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework/spring-web -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>5.0.8.RELEASE</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.0.8.RELEASE</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework/spring-jdbc -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.0.8.RELEASE</version>
</dependency>
<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.47</version>
</dependency>
</dependencies>
<build>
<finalName>lianxicrud</finalName>
</build>
</project>
第二步:在WEB-INF下:建立springMVC-servlet.xml文件。配置springMVC-servlet.xml和WEB-INF下的web.xml
1.springMVC-servlet.xml:主要配置数据源,视图解析器,以及注册拦截器......
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd">
<context:component-scan base-package="controller" />
<context:component-scan base-package="dao" />
<context:component-scan base-package="biz" />
<mvc:annotation-driven />
<!-- 配置数据源 -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="url" value="jdbc:mysql://localhost:3306/test" />
<property name="driverClassName" value="com.mysql.jdbc.Driver" />
<property name="username" value="root" />
<property name="password" value="66668888ZH" />
</bean>
<!-- 类似于ps对象的一个内容 -->
<bean id="jdbcTemplate"
class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource" />
</bean>
<!-- 视图解析器 -->
<bean id="irvr"
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="suffix" value=".jsp" />
<property name="prefix" value="/user/" />
</bean>
<!-- 注册拦截器 -->
<mvc:interceptors>
<bean id="encode" class="interruptor.EncodeInterceptor"/>
</mvc:interceptors> </beans>
web.xml:
<!DOCTYPE web-app PUBLIC
"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
"http://java.sun.com/dtd/web-app_2_3.dtd" > <web-app>
<display-name>Archetype Created Web Application</display-name>
<servlet>
<servlet-name>springMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>springMVC</servlet-name>
<url-pattern>*.mvc</url-pattern>
</servlet-mapping>
</web-app>
第三步:编写bean,dao,biz,controller,以及处理字符编码集的interrupt
1.bean包:
package bean;
public class EmpBean {
    private Integer empNo;
    private String eName;
    private String job;
    private Integer mgr;
    private String hireDate;
    private Double sal;
    private Double comm;
    private Integer deptNo;
    public EmpBean() {
        // TODO Auto-generated constructor stub
    }
    public Integer getEmpNo() {
        return empNo;
    }
    public void setEmpNo(Integer 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 Integer getMgr() {
        return mgr;
    }
    public void setMgr(Integer mgr) {
        this.mgr = mgr;
    }
    public String getHireDate() {
        return hireDate;
    }
    public void setHireDate(String hireDate) {
        this.hireDate = hireDate;
    }
    public Double getSal() {
        return sal;
    }
    public void setSal(Double sal) {
        this.sal = sal;
    }
    public Double getComm() {
        return comm;
    }
    public void setComm(Double comm) {
        this.comm = comm;
    }
    public Integer getDeptNo() {
        return deptNo;
    }
    public void setDeptNo(Integer deptNo) {
        this.deptNo = deptNo;
    }
    @Override
    public String toString() {
        return "EmpBean [empNo=" + empNo + ", eName=" + eName + ", job=" + job + ", mgr=" + mgr + ", hireDate="
                + hireDate + ", sal=" + sal + ", comm=" + comm + ", deptNo=" + deptNo + "]";
    }
}
2.dao包:
package dao; import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.stereotype.Repository; import bean.EmpBean; @Repository
public class EmpDAO { @Autowired
private JdbcTemplate jt; public void add(EmpBean eb) {
String sql = "insert into emp values(null,?,?,?,?,?,?,?)";
jt.update(sql, eb.geteName(),eb.getJob(),eb.getMgr(),eb.getHireDate(),eb.getSal(),eb.getComm(),eb.getDeptNo());
} public void delete(int empNo) {
String sql = "delete from emp where empno = ?";
jt.update(sql,empNo);
} public void update(EmpBean eb) {
String sql = "update emp set ename=?,job=?,mgr=?,hiredate=?,sal=?,comm=?,daptno=? where empno=?";
jt.update(sql,eb.geteName(),eb.getJob(),eb.getMgr(),eb.getHireDate(),eb.getSal(),eb.getComm(),eb.getDeptNo(),eb.getEmpNo());
} public List<EmpBean>findAll(){
String sql = "select * from emp";
return jt.query(sql, new RowMapperImpl());
} public EmpBean findById(int empNo) {
String sql = "select * from emp where empNo ='" + empNo + "'";
return jt.query(sql, new RowMapperImpl()).get(0);
}
} class RowMapperImpl implements RowMapper<EmpBean>{
//对象关系映射(ORM),将查询出来的结果映射成类的属性
@Override
public EmpBean mapRow(ResultSet rs, int rowNum) throws SQLException {
EmpBean eb = new EmpBean();
eb.setEmpNo(rs.getInt(1));
eb.seteName(rs.getString(2));
eb.setJob(rs.getString(3));
eb.setMgr(rs.getInt(4));
eb.setHireDate(rs.getString(5));
eb.setSal(rs.getDouble(6));
eb.setComm(rs.getDouble(7));
eb.setDeptNo(rs.getInt(8));
return eb;
}
}
3.biz包:
package biz; import java.util.List; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import bean.EmpBean;
import dao.EmpDAO; @Service
public class EmpBiz { @Autowired
private EmpDAO edao;
public void add(EmpBean eb) {
edao.add(eb);
} public void delete(int empNo) {
edao.delete(empNo);
} public void update(EmpBean eb) {
edao.update(eb);
} public List<EmpBean>findAll(){
return edao.findAll();
} public EmpBean findById(int empNo) {
return edao.findById(empNo);
}
}
4.controller包:
package controller; import javax.servlet.http.HttpServletRequest; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping; import bean.EmpBean;
import biz.EmpBiz; @Controller
@RequestMapping("/emp")
public class EmpController {
@Autowired
private EmpBiz eb;
@RequestMapping("/add")
public String add(EmpBean emp) {
eb.add(emp);
return "redirect:../index.jsp";
} @RequestMapping("/find")
public String findAll(HttpServletRequest request) {
request.getSession().setAttribute("ALLEMP",eb.findAll());
return "redirect:../index.jsp";
} @RequestMapping("/delete")
public String delete(int empNo) {
eb.delete(empNo);
return "redirect:../index.jsp";
} @RequestMapping("/findbyid")
public String findById(int empNo , HttpServletRequest request) {
request.getSession().setAttribute("EMPBEAN", eb.findById(empNo));
System.out.println("11111");
return "redirect:../update.jsp";
} @RequestMapping("/update")
public String update(EmpBean emp) {
eb.update(emp);
System.out.println("22222222");
return "redirect:../index.jsp";
}
}
interrupt包:
package interruptor; import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView; //建立一个拦截器(类似于Filter)
public class EncodeInterceptor implements HandlerInterceptor{ @Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
throws Exception {
} @Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
ModelAndView modelAndView) throws Exception {
}
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
throws Exception {
//针对post请求的编码集操作
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
return true;
} }
第四步:页面处理(为了方便index.jsp只查了这张表的姓名和员工编号,如果想显示更多可以进行查询,方法雷同)这里一定要注意加上isELIgnored="false",不然查不出来,下午找了一下午错误,原来忘了加这句话,哈哈
1.index.jsp:
<%@ page language="java" pageEncoding="utf-8" isELIgnored="false" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<body>
<c:if test="${empty ALLEMP}">
<c:redirect url="emp/find.mvc"/>
</c:if> <c:forEach var="ei" items="${ALLEMP}">
${ei.empNo} ${ei.eName}
<a href="emp/delete.mvc?empNo=${ei.empNo }">删除</a>
<a href="emp/findbyid.mvc?empNo=${ei.empNo }">修改</a>
<br/>
</c:forEach>
</body>
</html>
2.注册新员工页面:add.jsp:
<%@ page language="java" pageEncoding="utf-8" isELIgnored="false"%>
<html>
<head>
<title>注册新员工</title>
<style type="text/css">
table {
margin: 0 auto;
border: 1px gray solid;
width: 70%;
}
td,th{
border: 1px gray solid;
}
</style>
</head>
<body>
<form action="emp/add.mvc" method="post">
<table>
<tr>
<h2 align="center">公司员工注册表</h2>
</tr>
<tr>
<th>姓名</th>
<td>
<input type="text" name="eName"/>
</td>
</tr>
<tr>
<th>职位</th>
<td>
<input type="text" name="job"/>
</td>
</tr>
<tr>
<th>上司</th>
<td>
<input type="text" name="mgr"/>
</td>
</tr>
<tr>
<th>入职时间</th>
<td>
<input type="text" name="hireDate"/>
</td>
</tr>
<tr>
<th>薪资</th>
<td>
<input type="text" name="sal"/>
</td>
</tr>
<tr>
<th>奖金</th>
<td>
<input type="text" name="comm"/>
</td>
</tr>
<tr>
<th>部门</th>
<td>
<input type="text" name="deptNo"/>
</td>
</tr>
<tr>
<th colspan="1">
<input type="submit" values = "注册新员工"/>
</th>
</tr>
</table>
</form>
</body>
</html>
3.修改页面:update.jsp:
<%@ page language="java" pageEncoding="utf-8" isELIgnored="false"%>
<html>
<head>
<title>修改员工信息</title>
<style type="text/css">
table {
margin: 0 auto;
border: 1px gray solid;
width: 70%;
}
td,th{
border: 1px gray solid;
}
</style> </head>
<body> <form action="emp/update.mvc" method="post">
<input type="hidden" name="empNo" value="${EMPBEAN.empNo }"/>
<table>
<tr>
<h2 align="center">修改员工信息</h2>
</tr>
<tr>
<th>姓名</th>
<td>
<input type="text" name="eName" value="${EMPBEAN.eName }"/>
</td>
</tr>
<tr>
<th>职位</th>
<td>
<input type="text" name="job" value="${EMPBEAN.job }"/>
</td>
</tr>
<tr>
<th>上司</th>
<td>
<input type="text" name="mgr" value="${EMPBEAN.mgr }"/>
</td>
</tr>
<tr>
<th>入职时间</th>
<td>
<input type="text" name="hireDate" value="${EMPBEAN.hireDate }"/>
</td>
</tr>
<tr>
<th>薪金</th>
<td>
<input type="text" name="sal" value="${EMPBEAN.sal }"/>
</td>
</tr>
<tr>
<th>奖金</th>
<td>
<input type="text" name="comm" value="${EMPBEAN.comm }"/>
</td>
</tr>
<tr>
<th>部门</th>
<td>
<input type="text" name="daptNo" value="${EMPBEAN.deptNo }"/>
</td>
</tr>
<tr>
<th colspan="2">
<input type="submit" value="提交修改信息"/>
</th>
</tr>
</table>
</form> </body>
</html>
以上四大步就是SpringMVC实现增删改查的具体操作。
下面我们来进行测试:
1.首先我们启动我们的服务器,然后访问我们的index.jsp页面(查找测试):

2.访问add.jsp:并且填入新员工的信息(增加测试):
点击提交:

小仙女添加进来了
然后点击修改进行修改测试:我们把小仙女改成老仙女

修改完成。
然后点击老仙女的删除(删除测试)

删除成功。
其实这个还可以加入BootStrap将页面进行美化操作
springMVC实现增删改查的更多相关文章
- SpringMvc学习-增删改查
		本节主要介绍SpringMVC简单的增删改查功能. 1.查询 dao中的代码 public List<WeatherPojo> getAllWeather(){ String sql=&q ... 
- springMVC之增删改查
		一.核心原理 1. 用于发送请求给server: /home.htm 2. 请求被DispatchServlet拦截到 3. DispatchServlet通过HandleMapping检查url有没 ... 
- 基于SpringMVC的增删改查
		废话不多说,直接开始步骤! 1.创建一个Dynamic Web Project 2.在WEB-INF包下的lib文件夹中引入相关jar commons-logging-.jar jstl.jar sp ... 
- 【SpringBoot】11-1.Springboot整合Springmvc+Mybatis增删改查操作(下)
		整合过程:https://www.isdxh.com/68.html 一.增--增加用户 1.创建实体类 package com.dxh.pojo; public class Users { priv ... 
- SpringMVC框架下数据的增删改查,数据类型转换,数据格式化,数据校验,错误输入的消息回显
		在eclipse中javaEE环境下: 这儿并没有连接数据库,而是将数据存放在map集合中: 将各种架包导入lib下... web.xml文件配置为 <?xml version="1. ... 
- springMVC操作mongoDB增删改查
		下面是mongoDb简单的增删改查(新闻类) 附:query.addCriteria(Criteria.where("modelId").ne("").ne(n ... 
- SpringMVC,MyBatis商品的增删改查
		一.需求 商品的增删改查 二.工程结构 三.代码 1.Mapper层 (1) ItemsMapperCustom.java package com.tony.ssm.mapper; import ja ... 
- SSM框架搭建(Spring+SpringMVC+MyBatis)与easyui集成并实现增删改查实现
		一.用myEclipse初始化Web项目 新建一个web project: 二.创建包 controller //控制类 service //服务接口 service.impl //服务 ... 
- SpringMVC之简单的增删改查示例(SSM整合)
		本篇文章主要介绍了SpringMVC之简单的增删改查示例(SSM整合),这个例子是基于SpringMVC+Spring+Mybatis实现的.有兴趣的可以了解一下. 虽然已经在做关于SpringMVC ... 
随机推荐
- MediatR 知多少
			引言 首先不用查字典了,词典查无此词.猜测是作者笔误将Mediator写成MediatR了.废话少说,转入正题. 先来简单了解下这个开源项目MediatR(作者Jimmy Bogard,也是开源项目A ... 
- Eclipse 出现项目没有错但是项目名称却有红色感叹号或者红叉的解决办法
			错误的起因是本人因为一不小心点了下面圈出来的某一个按钮,具体记不清楚了(好像是"remove from build path"),然后整个项目变得很奇怪了,所有的包都变成了一个普通 ... 
- linux根目录下的各文件夹含义说明
			在早期的 UNIX 系统中,各个厂家各自定义了自己的 UNIX 系统文件目录,比较混乱. Linux 面世不久后,对文件目录进行了标准化,于1994年对根文件目录做了统一的规范, 推出 FHS ( F ... 
- numpy C语言源代码调试(一)
			近期学习numpy,希望了解numpy内部实现机制,尝试调试numpy的源代码,特别是其中的C语言源码. 在numpy的官方网站上,有numpy的开发人员手册: https://docs.scipy. ... 
- Android版数据结构与算法(三):基于链表的实现LinkedList源码彻底分析
			版权声明:本文出自汪磊的博客,未经作者允许禁止转载. LinkedList 是一个双向链表.它可以被当作堆栈.队列或双端队列进行操作.LinkedList相对于ArrayList来说,添加,删除元素效 ... 
- 如何使用JS来开发室内三维地图的轨迹回放功能
			在制作完成室内三维地图的功能后,最经常有的需求就是如何做人员的轨迹回放,一般流程都是从数据库中查询轨迹坐标后,经过后台查询接口返回给前端,接下来的事情都交给JS来完成. 如果想做好一个性能好的轨迹回 ... 
- c#发送邮件,可发送多个附件
			1:创建SendMail类 2:调用方法 SendMail send = new SendMail("123456@qq.com", "123456@163.com&qu ... 
- 联发科Helio P90,MT6779VWB芯片处理器
			联发科(p90)MT6779VWB芯片是一个集成了蓝牙.fm.wlan和gps模块的高度集成的基带平台,包括调制解调器和应用处理子系统.支持LTE/LTE-A和C2K智能手机应用程序.该芯片集成了两个 ... 
- [题解] 2038: [2009国家集训队]小Z的袜子(hose)
			莫队,卡常数 题目地址 思路 设\(\text{Vis[i]}\)为元素\(\text{i}\)在区间\(\text{[L,R]}\)的出现次数 考虑区间\(\text{[L,R]}\)和元素\(\t ... 
- 【XSS】对抗蠕虫 —— 如何让按钮不被 JS 自动点击
			前言 XSS 自动点按钮有什么危害? 在社交网络里,很多操作都是通过点击按钮发起的,例如发表留言.假如留言系统有 XSS,用户中招后除了基本攻击外,还能进行传播 -- XSS 自动填入留言内容,并模拟 ... 
