Mybatis与Spring整合
既然我们已经学了Mybatis的基本开发了,接下来就是Mybatis与Spring的整合了!
以下使用的是Oracle数据库来进行测试
导入jar包
- aopalliance.jar
- asm-3.3.1.jar
- aspectjweaver.jar
- c3p0-0.9.1.2.jar
- cglib-2.2.2.jar
- commons-logging.jar
- log4j-1.2.16.jar
- mybatis-3.1.1.jar
- mybatis-spring-1.1.1.jar
- mysql-connector-java-5.1.7-bin.jar
- ojdbc5.jar
- org.springframework.aop-3.0.5.RELEASE.jar
- org.springframework.asm-3.0.5.RELEASE.jar
- org.springframework.beans-3.0.5.RELEASE.jar
- org.springframework.context-3.0.5.RELEASE.jar
- org.springframework.core-3.0.5.RELEASE.jar
- org.springframework.expression-3.0.5.RELEASE.jar
- org.springframework.jdbc-3.0.5.RELEASE.jar
- org.springframework.orm-3.0.5.RELEASE.jar
- org.springframework.transaction-3.0.5.RELEASE.jar
- org.springframework.web.servlet-3.0.5.RELEASE.jar
- org.springframework.web-3.0.5.RELEASE.jar
创建表
create table emps(
eid number(5) primary key,
ename varchar2(20),
esal number(8,2),
esex varchar2(2)
);
创建实体
package entity;
/**
* 员工
* @author AdminTC
*/
public class Emp {
private Integer id;
private String name;
private Double sal;
private String sex;
public Emp(){}
public Emp(Integer id, String name, Double sal, String sex) {
this.id = id;
this.name = name;
this.sal = sal;
this.sex = sex;
}
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 getSal() {
return sal;
}
public void setSal(Double sal) {
this.sal = sal;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
}
创建实体与表的映射文件
insert into emps(eid,ename,esal,esex) values(#{id},#{name},#{sal},#{sex})
创建Mybatis映射文件配置环境
数据库的信息交由Spring管理!Mybatis配置文件负责加载对应映射文件即可
配置Spring核心过滤器【也是加载总配置文件】
DispatcherServlet
org.springframework.web.servlet.DispatcherServlet
contextConfigLocation
classpath:spring.xml
DispatcherServlet
*.action
配置数据库信息、事务
创建Dao、Service、Action
@Repository
public class EmpDao {
@Autowired
private SqlSessionFactory sqlSessionFactory;
/**
* 增加员工
*/
public void add(Emp emp) throws Exception {
SqlSession sqlSession = sqlSessionFactory.openSession();
sqlSession.insert("empNamespace.add", emp);
sqlSession.close();
}
}
@Service
public class EmpService {
@Autowired
private zhongfucheng.dao.EmpDao empDao;
public void addEmp(Emp emp) throws Exception {
empDao.add(emp);
}
}
@Controller
@RequestMapping("/emp")
public class EmpAction {
@Autowired
private EmpService empService;
@RequestMapping("/register")
public void register(Emp emp) throws Exception {
empService.addEmp(emp);
System.out.println("注册成功");
}
}
JSP页面测试
<%@ page language="java" pageEncoding="UTF-8"%>
员工注册
总结
- web.xml加载Spring配置文件
- Spring配置文件配置数据连接池,SessionFactory、事务、扫描注解
- Mybatis总配置文件、实体以及相对应的映射文件
- 将映射文件加入到总配置文件中。
如果文章有错的地方欢迎指正,大家互相交流。习惯在微信看技术文章,想要获取更多的Java资源的同学,可以关注微信公众号:Java3y