整合MyBatis的初步分析
概述
Mybatis是一个优秀的持久层框架,低层基于JDBC实现与数据库的交互。并在JDBC操作的基础上做了封装和优化,借助灵活的SQL定制,参数及结果集的映射方式,更好的适应了当前互联网技术的发展。Mybatis框架的简单应用架构如图所示:
环境测试代码实现
####### 在src/test/java目录中添加测试类,对mybatis框架整合进行基本测试,代码如下:
package com.cy.pj.goods.dao;
import java.sql.Connection;
import org.apache.ibatis.session.SqlSession;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
@SpringBootTest
public class MyBatisTests {
@Autowired
private SqlSession sqlSession;
@Test
public void testGetConnection() {
Connection conn=sqlSession.getConnection();
System.out.println("connection="+conn);
}
}
####### 在SpringBoot脚手架工程中,Spring框架会基于MyBatis框架低层配置,创建SqlSessionFactory对象,然后再通过此工厂对象创建SqlSession,最后基于Springku框架为测试类注入SqlSessionFactory对象,接下来,我们可以通过SqlSession对象实现与数据库的会话了。
整合MyBatis业务代码实现及原理分析
业务描述
####### 基于SpringBoot脚手架工程对MyBatis框架的整合,实现对商品库中商品数据的查询业务。
API架构设计
业务时序图分析
业务代码设计及实现
第一步:定义商品模块POJO对象类型(基于此对象存储商品数据),代码如下:
package com.cy.pj.goods.pojo;
import java.util.Date;
/**用于存储商品信息的pojo对象*/
public class Goods {
private Long id;
private String name;
private String remark;
private Date createdTime;
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getRemark() {
return remark;
}
public void setRemark(String remark) {
this.remark = remark;
}
public Date getCreatedTime() {
return createdTime;
}
public void setCreatedTime(Date createdTime) {
this.createdTime = createdTime;
}
}
第二步:定义商品模块持久层对象GoodsDao接口及方法映射,代码如下
GoodsDao接口及方法定义
package com.cy.pj.goods.dao;
import com.cy.pj.goods.pojo.Goods;
import org.apache.ibatis.annotations.Mapper;
import java.util.List;
/**商品模块持久层对象,基于此对象的实现类操作商品库中的数据
* @Mapper MyBatis框架中定义,用于描述持久层接口,告诉mybatis
* 这个接口的实现类由mybatis创建,并且交给spring框架管理.
* */
@Mapper
public interface GoodsDao {
List<Goods> findGoods();
}
GoodsDao接口映射文件及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="com.cy.pj.goods.dao.GoodsDao">
<select id="findGoods" resultType="com.cy.pj.goods.pojo.Goods">
select * from tb_goods
</select>
</mapper>
测试代码的编写及运行
定义单元测试类,对GoodsDao方法进行单元测试,例如: