English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
CRUD(생성, 읽기, 업데이트 및 삭제) 애플리케이션은 어떤 프로젝트를 만들기 위한 가장 중요한 애플리케이션입니다. 그것은 대형 프로젝트를 개발하는 아이디어를 제공합니다. SpringMVC에서는 간단한 CRUD 애플리케이션을 개발할 수 있습니다.
在这里,我们使用 여기서는 사용하고 있습니다. JdbcTemplate
표를 생성합니다99여기서는 MySQL 데이터베이스에 존재하는 emp를 사용하고 있습니다.4표. 그것은 다음과 같습니다:
pom.xml 파일에 의존성을 추가합니다.
.0.-- <!//https:/mvnrepository.com/artifact/spring-pom.xml --> jdbc <dependency>/<groupId>org.springframework <groupId>org.springframework-webmvc/<artifactId>jdbc <version>5.1.1.RELEASE</version> </dependency> .0.-- <!//https:/mvnrepository.com/webmvc/org.apache.tomcat-tomcat --> jdbc jasper/<groupId>org.springframework <groupId>org.apache.tomcat-<artifactId>tomcat/<artifactId>jdbc <version>9java<12</version> </dependency> .0.-- <!//https:/mvnrepository.com/alpha/alpha-jasper --> jdbc javax.servlet/<groupId>org.springframework api-<artifactId>servlet/<artifactId>jdbc <version>3api-.0-1</version> </dependency> .0.-- <!//https:/mvnrepository.com/alpha/jstl --> jdbc javax.servlet/<groupId>org.springframework <groupId>javax.servlet/<artifactId>jdbc <version>1.2</version> </dependency> .0.-- <!//https:/mvnrepository.com/<artifactId>jstl/<artifactId>jstl-<artifactId>mysql-mysql --> jdbc java/<groupId>org.springframework <groupId>mysql-<artifactId>mysql-connector/<artifactId>jdbc <version>8java<11</version> </dependency> .0.-- <!//https:/mvnrepository.com/artifact/spring-org.springframework --> jdbc <dependency>/<groupId>org.springframework <groupId>org.springframework-<artifactId>spring/<artifactId>jdbc <version>5.1.1.RELEASE</version> </dependency>
여기서는 bean 클래스가 데이터베이스에 존재하는 필드(또는 setter와 getter 메서드)에 해당합니다.
Emp.java
package com.w3codebox.beans; public class Emp { private int id; private String name; private float salary; private String designation; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public float getSalary() { return salary; } public void setSalary(float salary) { this.salary = salary; } public String getDesignation() { return designation; } public void setDesignation(String designation) { this.designation = designation; } }
EmpController.java
package com.w3codebox.controllers; import java.util.List; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.ModelAttribute; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import com.w3codebox.beans.Emp; import com.w3codebox.dao.EmpDao; @Controller public class EmpController { @Autowired EmpDao dao;//XML 파일에서 DAO를 주입합니다 /*데이터 입력을 위해 양식을 표시하며, 여기서 "command"은 예약된 요청 속성입니다 *객체 데이터를 양식에 표시하는 데 사용됩니다 */ @RequestMapping("/empform") public String showform(Model m){ m.addAttribute("command", new Emp()); return "empform"; } /*It saves object into database. The @ModelAttribute puts request data * into model object. You need to mention RequestMethod.POST method * because default request is GET*/ @RequestMapping(value="/save", method = RequestMethod.POST) public String save(@ModelAttribute("emp") Emp emp){ dao.save(emp); return "redirect:/viewemp";//will redirect to viewemp request mapping } /* It provides list of employees in model object */ @RequestMapping("/viewemp") public String viewemp(Model m){ List<Emp> list = dao.getEmployees(); m.addAttribute("list", list); return "viewemp"; } /* It displays object data into form for the given id. * The @PathVariable puts URL data into variable.*/ @RequestMapping(value="/editemp/{id}") public String edit(@PathVariable int id, Model m){ Emp emp = dao.getEmpById(id); m.addAttribute("command", emp); return "empeditform"; } /* 이 모델 오브젝트를 업데이트합니다. */ @RequestMapping(value="/editsave", method = RequestMethod.POST) public String editsave(@ModelAttribute("emp") Emp emp){ dao.update(emp); return "redirect:/viewemp"; } /* It deletes record for the given id in URL and redirects to /viewemp */ @RequestMapping(value="/deleteemp/{id}", method = RequestMethod.GET) public String delete(@PathVariable int id){ dao.delete(id); return "redirect:/viewemp"; } }
让我们创建一个DAO类以访问数据库中所需的数据。
EmpDao.java
package com.w3codebox.dao; import java.sql.ResultSet; import java.sql.SQLException; import java.util.List; import org.springframework.jdbc.core.BeanPropertyRowMapper; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.core.RowMapper; import com.w3codebox.beans.Emp; public class EmpDao { JdbcTemplate template; public void setTemplate(JdbcTemplate template) { this.template = template; } public int save(Emp p){ String sql="insert into Emp99(name,salary,designation) values('"+p.getName()+"',"+p.getSalary()+"'"+p.getDesignation()+"')"; return template.update(sql); } public int update(Emp p){ String sql="update Emp99 set name='"+p.getName()+"', salary="+p.getSalary()+"designation='"+p.getDesignation()+"' where id="+p.getId()+""; return template.update(sql); } public int delete(int id){ String sql="delete from Emp99 where id="+id+""; return template.update(sql); } public Emp getEmpById(int id){ String sql="select * from Emp99 where id=?"; return template.queryForObject(sql, new Object[]{id},new BeanPropertyRowMapper<Emp>(Emp.class)); } public List<Emp> getEmployees(){ return template.query("select * from Emp99",new RowMapper<Emp>(){ public Emp mapRow(ResultSet rs, int row) throws SQLException { Emp e=new Emp(); e.setId(rs.getInt(1)); e.setName(rs.getString(2)); e.setSalary(rs.getfloat(3)); e.setDesignation(rs.getString(4)); return e; } }); } }
web.xml
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0"> <display-name>스프링MVC</display-name> <서블릿 <서블릿-name>봄</servlet-name> <서블릿-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <load-on-startup>1</load-on-startup> </서블릿> <서블릿-mapping> <서블릿-name>봄</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> </web-app>
spring-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="com.w3codebox.controllers"></context:component-scan> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/jsp/></property> <property name="suffix" value=".jsp"></property> </bean> <bean id="ds" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver"></property> <property name="url" value="jdbc:mysql:"><//localhost:3306/test"></property> <property name="username" value=""></property> <property name="password" value=""></property> </bean> <bean id="jt" class="org.springframework.jdbc.core.JdbcTemplate"> <property name="dataSource" ref="ds"></property> </bean> <bean id="dao" class="com.w3codebox.dao.EmpDao"> <property name="template" ref="jt"></property> </bean> </beans>
index.jsp
<a href="empform">Add Employee</a> <a href="viewemp">View Employees</a>
empform.jsp
<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form"%> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <h1>Add new Employee</h1> <form:form method="post" action="save"> <table > <tr> td>Name : </td> <td><form:input path="name" /></td> </tr> <tr> td>Salary :</td> <td><form:input path="salary" /></td> </tr> <tr> td>Designation :</td> <td><form:input path="designation" /></td> </tr> <tr> td> </td> td><input type="submit" value="Save" /></td> </tr> </table> </form:form>
empeditform.jsp
여기"/SpringMVCCRUDSimple"은 프로젝트 이름입니다. 다른 프로젝트 이름을 사용하는 경우 이 이름을 변경하십시오. 실시간 애플리케이션에서는 전체 URL을 제공할 수 있습니다.
<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form"%> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <h1>Edit Employee</h1> <form:form method="POST" action="/SpringMVCCRUDSimple/editsave"> <table > <tr> td></td> <td><form:hidden path="id" /></td> </tr> <tr> td>Name : </td> <td><form:input path="name" /></td> </tr> <tr> td>Salary :</td> <td><form:input path="salary" /></td> </tr> <tr> td>Designation :</td> <td><form:input path="designation" /></td> </tr> <tr> td> </td> <td><input type="submit" value="Edit Save" /></td> </tr> </table> </form:form>
viewemp.jsp
<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form"%> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <h1>직원 목록</h1> <table border="2" width="70%" cellpadding="2"> <tr><th>Id</th><th>이름</th><th>급여</th><th>직위</th><th>편집</th><th>삭제</th></tr> <c:forEach var="emp" items="${list}"> <tr> ${emp.id}</td> ${emp.name}</td> ${emp.salary}</td> ${emp.designation}</td> <td><a href="editemp/${emp.id}>편집</a></td> <td><a href="deleteemp/${emp.id}>삭제</a></td> </tr> </c:forEach> </table> <br/> <a href="empform">Add new Employee</a>
출력:
클릭 직원 추가다음 표를 볼 수 있습니다.
양식을 작성한 후 저장 클릭항목을 데이터베이스에 추가하려면
지금, 다음을 클릭하세요 편집제공된 내용에 대해 일부 데이터를 변경하려면
지금, 다음을 클릭하세요 편집 저장변경된 항목을 데이터베이스에 추가합니다。
지금, 다음을 클릭하세요 삭제데이터베이스에서 항목을 제거합니다。