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.运行,输出结果