Spring MVC与jdbc整合

1.搭建开发环境

---引入ioc、aop、dao、webmvc、mysql驱动包、dbcp包

---在src下添加applicationContext.xml

2.编写entity包下的实体类,dao包下的操作数据库的类,以及mapper包下的查询时封装成对象的类


①entity下的Emp类

package entity;
import java.io.Serializable;
public class Emp implements Serializable{
private Integer id;
private String name;
private Double salary;
private Integer age;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Double getSalary() {
return salary;
}
public void setSalary(Double salary) {
this.salary = salary;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}

}

②dao下的EmpDao类

@Repository
public class EmpDao {
@Resource
private JdbcTemplate template;
public List<Emp> findAll(){
String sql = "select * from emp";
EmpRowMapper rowMapper = new EmpRowMapper();
List<Emp> list = template.query(sql, rowMapper);
return list;
}

}

③mapper下的EmpRowMapper类

public class EmpRowMapper implements RowMapper{
@Override
public Object mapRow(ResultSet rs, int index) throws SQLException {
Emp emp = new Emp();
emp.setId(rs.getInt("id"));
emp.setName(rs.getString("name"));
emp.setSalary(rs.getDouble("salary"));
emp.setAge(rs.getInt("age"));
return emp;
}

}

3.配置文件

①web.xml

<servlet>
    <servlet-name>springmvc</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>classpath:applicationContext.xml</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>springmvc</servlet-name>
    <url-pattern>*.do</url-pattern>

  </servlet-mapping>

②applicationContext.xml

  <context:component-scan base-package="dao"></context:component-scan>

  <bean id="template" class="org.springframework.jdbc.core.JdbcTemplate">
    <property name="dataSource" ref="dbcp"></property>
  </bean>
  <bean id="dbcp" class="org.apache.commons.dbcp.BasicDataSource">
    <property name="username" value="root"></property>
    <property name="password" value="123456"></property>
    <property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
    <property name="url" value="jdbc:mysql:///mybatis"></property>
  </bean>
    
  <mvc:annotation-driven></mvc:annotation-driven>
  <context:component-scan base-package="controller"></context:component-scan>
  <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="prefix" value="/WEB-INF/"></property>
    <property name="suffix" value=".jsp"></property>
  </bean>

</beans>

4.编写ListController和jsp界面

①ListController

@Controller
public class ListController {
@RequestMapping("/list.do")
public ModelAndView execute(){
ModelAndView mav = new ModelAndView();
//获取dao的对象不能通过new新建来获取,要通过配置来获取
String conf = "applicationContext.xml";
ApplicationContext ac = new ClassPathXmlApplicationContext(conf);
EmpDao empDao = ac.getBean("empDao",EmpDao.class);

List<Emp> list = empDao.findAll();
mav.getModel().put("list1", list);
mav.setViewName("list");
return mav;
}

}

②list.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@ page import="dao.*,entity.*,java.util.*" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
  </head>
  <body>
    <table>
      <tr>
        <td>ID</td>
        <td>name</td>
      </tr>
      <%
        List<Emp> list = (List<Emp>)request.getAttribute("list1");
        for(int i=0;i<list.size();i++){
          Emp e = list.get(i);
       %>
       <tr>
         <td><%=e.getId() %></td>
         <td><%=e.getName() %></td>
       </tr>
       <%
       }
        %>
    </table>
  </body>

</html>

5.效果


猜你喜欢

转载自blog.csdn.net/qq_39924152/article/details/80546724
今日推荐