实体类:Student.java

  1. package demo.entity;
  2. public class Student
  3. {
  4. private int id;
  5. private String name;
  6. private String sex;
  7. private String address;
  8. public int getId()
  9. {
  10. return id;
  11. }
  12. public void setId(int id)
  13. {
  14. this.id = id;
  15. }
  16. public String getName()
  17. {
  18. return name;
  19. }
  20. public void setName(String name)
  21. {
  22. this.name = name;
  23. }
  24. public String getSex()
  25. {
  26. return sex;
  27. }
  28. public void setSex(String sex)
  29. {
  30. this.sex = sex;
  31. }
  32. public String getAddress()
  33. {
  34. return address;
  35. }
  36. public void setAddress(String address)
  37. {
  38. this.address = address;
  39. }
  40. }

IStudentDao.java

  1. package demo.dao;
  2. import java.util.List;
  3. import demo.entity.Student;
  4. public interface IStudentDao
  5. {
  6. public void insert(Student stu);
  7. public void delete(int id);
  8. public void update(Student stu);
  9. public List<Student> findAll();
  10. public Student findById(int id);
  11. }

StudentDaoImpl.java

  1. package demo.dao.impl;
  2. import java.util.List;
  3. import java.util.Map;
  4. import javax.annotation.Resource;
  5. import org.springframework.jdbc.core.BeanPropertyRowMapper;
  6. import demo.dao.IStudentDao;
  7. import demo.entity.Student;
  8. public class StudentDaoImpl implements IStudentDao
  9. {
  10. public static final String INSERT = "insert into student(name,sex,address) values(?,?,?)";
  11. public static final String DELETE = "delete from student where id=?";
  12. public static final String UPDATE = "update student set name=?,sex=?,address=? where id=?";
  13. public static final String FINDALL = "select * from student";
  14. public static final String FINDBYID = "select * from student where id=?";
  15. private org.springframework.jdbc.core.simple.SimpleJdbcTemplate simpleJdbcTemplate;
  16. @Resource
  17. public void setSimpleJdbcTemplate(
  18. org.springframework.jdbc.core.simple.SimpleJdbcTemplate simpleJdbcTemplate)
  19. {
  20. this.simpleJdbcTemplate = simpleJdbcTemplate;
  21. }
  22. public void delete(int id)
  23. {
  24. // TODO Auto-generated method stub
  25. this.simpleJdbcTemplate.update(DELETE, id);
  26. }
  27. @SuppressWarnings("deprecation")
  28. public List<Student> findAll()
  29. {
  30. // TODO Auto-generated method stub
  31. List<Student> stuList = this.simpleJdbcTemplate.query(FINDALL,new BeanPropertyRowMapper<Student>(Student.class));
  32. return stuList;
  33. }
  34. public Student findById(int id)
  35. {
  36. // TODO Auto-generated method stub
  37. Map<String, Object> stuMap = this.simpleJdbcTemplate.queryForMap(FINDBYID, id);
  38. Student stu = new Student();
  39. stu.setId(id);
  40. stu.setName(stuMap.get("name").toString());
  41. stu.setSex(stuMap.get("sex").toString());
  42. stu.setAddress(stuMap.get("address").toString());
  43. return stu;
  44. }
  45. public void insert(Student stu)
  46. {
  47. // TODO Auto-generated method stub
  48. this.simpleJdbcTemplate.update(INSERT, stu.getName(),stu.getSex(),stu.getAddress());
  49. }
  50. public void update(Student stu)
  51. {
  52. // TODO Auto-generated method stub
  53. this.simpleJdbcTemplate.update(UPDATE, stu.getName(),stu.getSex(),stu.getAddress(),stu.getId());
  54. }
  55. }

IStudentService.java

  1. package demo.service;
  2. import java.util.List;
  3. import demo.entity.Student;
  4. public interface IStudentService
  5. {
  6. public void insert(Student stu);
  7. public void delete(int id);
  8. public void update(Student stu);
  9. public List<Student> findAll();
  10. public Student findById(int id);
  11. }

StudentServiceImpl.java

  1. package demo.service.impl;
  2. import java.util.List;
  3. import javax.annotation.Resource;
  4. import demo.dao.IStudentDao;
  5. import demo.entity.Student;
  6. import demo.service.IStudentService;
  7. public class StudentServiceImpl implements IStudentService
  8. {
  9. private IStudentDao stuDao;
  10. @Resource
  11. public void setStuDao(IStudentDao stuDao)
  12. {
  13. this.stuDao = stuDao;
  14. }
  15. public void delete(int id)
  16. {
  17. // TODO Auto-generated method stub
  18. stuDao.delete(id);
  19. }
  20. public List<Student> findAll()
  21. {
  22. // TODO Auto-generated method stub
  23. return stuDao.findAll();
  24. }
  25. public Student findById(int id)
  26. {
  27. // TODO Auto-generated method stub
  28. return stuDao.findById(id);
  29. }
  30. public void insert(Student stu)
  31. {
  32. // TODO Auto-generated method stub
  33. stuDao.insert(stu);
  34. }
  35. public void update(Student stu)
  36. {
  37. // TODO Auto-generated method stub
  38. stuDao.update(stu);
  39. }
  40. }

StudentController.java

  1. package demo.controller;
  2. import java.io.UnsupportedEncodingException;
  3. import java.util.List;
  4. import javax.annotation.Resource;
  5. import javax.servlet.http.HttpServletRequest;
  6. import javax.servlet.http.HttpServletResponse;
  7. import org.springframework.stereotype.Controller;
  8. import org.springframework.ui.ModelMap;
  9. import org.springframework.web.bind.annotation.PathVariable;
  10. import org.springframework.web.bind.annotation.RequestMapping;
  11. import org.springframework.web.bind.annotation.RequestMethod;
  12. import org.springframework.web.servlet.ModelAndView;
  13. import demo.entity.Student;
  14. import demo.service.IStudentService;
  15. @Controller
  16. @RequestMapping("/student")
  17. public class StudentController
  18. {
  19. private IStudentService stuService;
  20. @Resource
  21. public void setStuService(IStudentService stuService)
  22. {
  23. this.stuService = stuService;
  24. }
  25. /**
  26. * 全部
  27. */
  28. @RequestMapping(value = "/all", method = RequestMethod.GET)
  29. public ModelAndView findAll(HttpServletRequest request,
  30. HttpServletResponse response, ModelMap modelMap)
  31. {
  32. List<Student> stuList = stuService.findAll();
  33. modelMap.put("stuList", stuList);
  34. return new ModelAndView("allStudent", modelMap);
  35. }
  36. /**
  37. * 删除
  38. */
  39. @RequestMapping(value = "/delete/{id}", method = RequestMethod.GET)
  40. public String delete(HttpServletRequest request,
  41. HttpServletResponse response, @PathVariable("id")
  42. int id, ModelMap modelMap)
  43. {
  44. stuService.delete(id);
  45. return "redirect:/student/all.do";
  46. }
  47. /**
  48. * 添加
  49. */
  50. @RequestMapping(value = "/add", method = RequestMethod.POST)
  51. public String addStudent(HttpServletRequest request,
  52. HttpServletResponse response, Student stu)
  53. throws UnsupportedEncodingException
  54. {
  55. stuService.insert(stu);
  56. return "redirect:/student/all.do";
  57. }
  58. /**
  59. * pre4Update
  60. */
  61. @RequestMapping("/pre4Update/{id}")
  62. public ModelAndView pre4Update(HttpServletRequest request,
  63. HttpServletResponse response, @PathVariable("id")
  64. int id, ModelMap modelMap)
  65. {
  66. Student stu = stuService.findById(id);
  67. modelMap.put("stu", stu);
  68. return new ModelAndView("updateStudent", modelMap);
  69. }
  70. /**
  71. * updateStudent
  72. */
  73. @RequestMapping("/updateStudent")
  74. public String updateStudent(HttpServletRequest request,
  75. HttpServletResponse response, Student stu)
  76. {
  77. stuService.update(stu);
  78. return "redirect:/student/all.do";
  79. }
  80. /**
  81. * 跳转:用于跳转的过度
  82. */
  83. @RequestMapping(value = "/redir/{url}", method = RequestMethod.GET)
  84. public String sendRedirect(HttpServletRequest request,
  85. HttpServletResponse response, @PathVariable("url")
  86. String url)
  87. {
  88. return url;
  89. }
  90. }

================================================ 
配置文件: 
jdbc.properties

  1. jdbc.driverClassName=com.mysql.jdbc.Driver
  2. jdbc.url=jdbc:mysql://localhost:3306/demo?characterEncoding=utf-8
  3. jdbc.username=root
  4. jdbc.password=root

servlet.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xmlns:mvc="http://www.springframework.org/schema/mvc"
  5. xmlns:context="http://www.springframework.org/schema/context"
  6. xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
  7. http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
  8. http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">
  9. <context:component-scan base-package="demo.controller"></context:component-scan>
  10. <!-- 内部资源视图解析器 (用于支持Servlet、JSP视图解析) -->
  11. <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
  12. <property name="prefix" value="/WEB-INF/jsp/"/>
  13. <property name="suffix" value=".jsp"/>
  14. </bean>
  15. <!-- 数据库连接配置文件路径及读取方式 -->
  16. <bean id="propertyConfigurer"
  17. class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
  18. <property name="locations">
  19. <list>
  20. <value>classpath:jdbc.properties</value>
  21. </list>
  22. </property>
  23. </bean>
  24. <!-- 数据库连接池 -->
  25. <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
  26. destroy-method="close">
  27. <property name="driverClassName" value="${jdbc.driverClassName}" />
  28. <property name="url" value="${jdbc.url}" />
  29. <property name="username" value="${jdbc.username}" />
  30. <property name="password" value="${jdbc.password}" />
  31. </bean>
  32. <bean id="simpleJdbcTemplate"
  33. class="org.springframework.jdbc.core.simple.SimpleJdbcTemplate">
  34. <constructor-arg><ref bean="dataSource"/></constructor-arg>
  35. </bean>
  36. <!-- spring JDBC -->
  37. <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
  38. <property name="dataSource" ref="dataSource" />
  39. </bean>
  40. </beans>

applicationContext-dao.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" " http://www.springframework.org/dtd/spring-beans.dtd">
  3. <beans>
  4. <bean id="stuDao" class="demo.dao.impl.StudentDaoImpl">
  5. <property name="simpleJdbcTemplate"
  6. ref="simpleJdbcTemplate" />
  7. </bean>
  8. </beans>

applicationContext-service.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" " http://www.springframework.org/dtd/spring-beans.dtd">
  3. <beans>
  4. <bean id="stuService" class="demo.service.impl.StudentServiceImpl">
  5. <property name="stuDao" ref="stuDao"/>
  6. </bean>
  7. </beans>

web.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
  5. http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
  6. <welcome-file-list>
  7. <welcome-file>index.jsp</welcome-file>
  8. </welcome-file-list>
  9. <servlet>
  10. <servlet-name>demo2</servlet-name>
  11. <servlet-class>
  12. org.springframework.web.servlet.DispatcherServlet
  13. </servlet-class>
  14. <init-param>
  15. <param-name>contextConfigLocation</param-name>
  16. <param-value>/WEB-INF/classes/spring/*.xml</param-value>
  17. </init-param>
  18. <load-on-startup>1</load-on-startup>
  19. </servlet>
  20. <servlet-mapping>
  21. <servlet-name>demo2</servlet-name>
  22. <url-pattern>*.do</url-pattern>
  23. </servlet-mapping>
  24. <!-- 处理乱码 -->
  25. <filter>
  26. <filter-name>encodingFilter</filter-name>
  27. <filter-class>
  28. org.springframework.web.filter.CharacterEncodingFilter
  29. </filter-class>
  30. <init-param>
  31. <param-name>encoding</param-name>
  32. <param-value>utf-8</param-value>
  33. </init-param>
  34. <init-param>
  35. <param-name>forceEncoding</param-name>
  36. <param-value>true</param-value>
  37. </init-param>
  38. </filter>
  39. <filter-mapping>
  40. <filter-name>encodingFilter</filter-name>
  41. <url-pattern>/*</url-pattern>
  42. </filter-mapping>
  43. </web-app>

================== 
allStudent.jsp

    1. <%@ page language="java" pageEncoding="utf-8"%>
    2. <%@ taglib uri="http://java.sun.com/jstl/core_rt" prefix="e"%>
    3. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    4. <html>
    5. <head>
    6. <title>Student列表</title>
    7. </head>
    8. <table width="50%" border="1">
    9. <tr>
    10. <td>id</td>
    11. <td>姓名</td>
    12. <td>性别</td>
    13. <td>地址</td>
    14. <td>操作</td>
    15. </tr>
    16. <e:forEach items="${requestScope.stuList}" var="stu">
    17. <tr>
    18. <td>${stu.id}</td>
    19. <td>${stu.name}</td>
    20. <td>${stu.sex}</td>
    21. <td>${stu.address}</td>
    22. <td><a href="pre4Update/${stu.id}.do">修改</a>||<a href="delete/${stu.id}/${stu.name}.do">删除</a></td>
    23. </tr>
    24. </e:forEach>
    25. </table>
    26. <a href="redir/addStudent.do">添加</a>
    27. <body>
    28. </body>
    29. </html>

crud springmvc的更多相关文章

  1. 学习SpringMVC——你们要的REST风格的CRUD来了

    来来来,让一下,客官,您要的REST清蒸CRUD来了,火候刚刚好,不油不腻,请慢用~~~ 如果说前面是准备调料,洗菜,切菜,摆盘,那么今天就来完整的上道菜,主要说的是基于REST风格实现数据的增删改查 ...

  2. 【SpringMVC】SpringMVC系列11之Restful的CRUD

      11.Restful的CRUD 11.1.需求 11.2.POST转化为PUT.DELETE的fileter 11.3.查询所有 11.4.添加 11.5.删除     优雅的 REST 风格的资 ...

  3. 构建web应用之——SpringMVC实现CRUD

    配置好SpringMVC最基本的配置后,开始实现处理数据的CRUD(CREATE, READ, UPDATE, DELETE) 为实现模块上的松耦合,我们将与数据库的交互任务交给DAO(Data Ac ...

  4. SpringMvc+Mybatis+Maven+Mysql做一个CRUD的简单例子

    本文档结合 SpringMVC. Mybatis. MySQL,说明如何实现一个简单的数据库单表 CRUD操作.开发工具使用集成了spring mvc的eclipse(Spring Tool Suit ...

  5. SpringMVC 使用 RESTful 架构实现 CRUD 操作

    软件152 余建强 源码下载:http://download.csdn.net/detail/qq_35318576/9826210 1 使用框架 SpringMVC.Maven.Ajax.JSTL. ...

  6. 21-spring学习-springMVC实现CRUD

    结合业务层实现一共完成CRUD操作 1,定义一共IMessageServese接口 package com.SpringMVC.Service; import java.util.Map; impor ...

  7. 使用springmvc时报错org.springframework.beans.NullValueInNestedPathException: Invalid property 'department' of bean class [com.atguigu.springmvc.crud.entities.Employee]:

    使用springmvc时报错 org.springframework.beans.NullValueInNestedPathException: Invalid property 'departmen ...

  8. SpringMVC 学习笔记(五) 基于RESTful的CRUD

    1.1. 概述 当提交的表单带有_method字段时,通过HiddenHttpMethodFilter 将 POST 请求转换成 DELETE.PUT请求,加上@PathVariable注解从而实现  ...

  9. SpringMVC案例1——对User表进行CRUD操作

    ------------------------------------------------------------------web.xml--------------------------- ...

随机推荐

  1. Mysql 格式化日期格式

    DATE_FORMAT(date, format) 根据格式串format 格式化日期或日期和时间值date,返回结果串. 可用DATE_FORMAT( ) 来格式化DATE 或DATETIME 值, ...

  2. server2008R2服务器开启远程

    通常我们开启远程桌面只需要在我的电脑那边把远程的打开就可以了,然后允许访问 上面说的这些其实晚上很多都有的,自己找一下,这边是自己遇到的一点问题,就是弄了很久,按网上说的弄很久,发现问题原来是在,路由 ...

  3. WP开发笔记——去除 HTML 标签

    获取到一段HTML类型的信息,显示在WP的webbrowser控件中,如果不加处理的话,会显示出各种神烦的HTML标签. 这时,需要我们将这HTML类型的信息进行处理去除HTML标签后再显示出来,这里 ...

  4. 身处IT的你对身边人都有哪些影响

    前不久,跟外甥一起吃饭:他明年就要中考了,我就想,这马上就到人生的关键路口了,看他自己对将来有什么想法没:就问了句:勇勇,你以后想学习哪些方面的东西或者想从事什么工作呢?他简单的说了句:我要跟你一样学 ...

  5. phpStudy 2016 更新下载,新版支持php7.0

    目标:让天下没有难配的php环境. phpStudy Linux版&Win版同步上线 支持Apache/Nginx/Tengine/Lighttpd/IIS7/8/6 『软件简介』该程序包集成 ...

  6. Stanford parser学习:LexicalizedParser类分析

    上次(http://www.cnblogs.com/stGeekpower/p/3457746.html)主要是对应于javadoc写了下LexicalizedParser类main函数的功能,这次看 ...

  7. 51nod1270 数组的最大代价(简单dp)

    ---恢复内容开始--- 1270 数组的最大代价 题目来源: HackerRank 基准时间限制:1 秒 空间限制:131072 KB 分值: 20 难度:3级算法题  收藏  关注 数组A包含N个 ...

  8. Win7构造wifi热点【Written By KillerLegend】

    1:Win+R打开DOS,输入以下命令然后回车,不要关闭该DOS窗口: netsh wlan set hostednetwork  mode = allow ssid =你的wifi热点名字  key ...

  9. mysql 的数据类型

    mysql 的数据类型(描述的是字段)三大类:一.整型:1.tinyint(M),其中M是显示宽度,需要配合zerofill,就是前面0填充,存储单位为1个字节(8位),无符文是最大能存储范围0000 ...

  10. sql2012安装过程中出现个一个问题

    最近安装了一次SQLSERVER2012,遇到了一个小问题,截图如下: 就是上图中状态为失败的项,点开之后,会弹出下面的一个框: 在网上搜了之后,有了这样的答案: http://www.cnblogs ...