Spring与MyBatis整合

1.配置开发环境

---导入ioc、aop、dao、dbcp、mybatis、mysql、mybatis-spring的jar包

---引入applicationContet.xml、EmpMapper.xml(定义SQL语句)配置文件

    (SqlMapConfig.xml 配置dbcp的将不需要,会在applicationContext.xml中对dbcp进行配置)

2.要点

①有MapperFactoryBean组件:封装了根据Mapper映射器接口生成实现组件的功能

    以前是通过EmpMapper.xml的namespace指定的(现在也需要指明包名.接口名)

②有SqlSessionFactory组件:封装了创建SqlSessionFactory过程

    不用再写工具类用于获取session

3.配置结构如下:

 

4.写一个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;
}

}

4.添加配置文件,并进行配置

  <bean id="empDao" class="org.mybatis.spring.mapper.MapperFactoryBean">
    <property name="mapperInterface" value="dao.EmpDao"></property>
    <property name="sqlSessionFactory" ref="ssf"></property>
  </bean>
  <!-- 创建sqlSessionFactory -->
  <bean id="ssf" class="org.mybatis.spring.SqlSessionFactoryBean">
    <!-- 注入DataSource:使用dbcp连接池 -->
    <property name="dataSource" ref="dbcp"></property>
    <!-- 注入SQL语句文件:加载多个文件 -->
    <property name="mapperLocations" value="classpath:sql/*.xml"></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>

5.定义一个EmpDao接口类(不用写:@Repository)

public interface EmpDao {
public List<Emp> findAll();
public Emp findById(int id);

}

6.写一个EmpMapper.xml文件:用于定义SQL语句

<?xml version="1.0" encoding="UTF-8" ?>    
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"    
 "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="dao.EmpDao">
  <select id="findAll" resultType="entity.Emp">
    select * from emp
  </select>
  <select id="findById" parameterType="int" resultType="entity.Emp">
    select * from emp where id=#{id}
  </select>
</mapper>

7.写一个测试类,用于测试获取的结果

public class TestEmpDao {
public static void main(String[] args) {
String conf="applicationContext.xml";
ApplicationContext ac = new ClassPathXmlApplicationContext(conf);
EmpDao empDao = ac.getBean("empDao",EmpDao.class);
List<Emp> list = empDao.findAll();
for(Emp e : list){
System.out.println(e.getName());
}
}

}

8.运行,输出结果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值