目录
1、什么是mybatis
Mybatis是一个开源、轻量级的数据持久化框架,是 JDBC 和 Hibernate 的替代方案。MyBatis内部封装了 JDBC,简化了加载驱动、创建连接、创建 statement 等繁杂的过程,开发者只需要关注 SQL 语句本身。
2、mybatis项目搭建
项目的搭建我们可以参照官方文档,该项目基于mybatis-3.5.10,不加入Spring整合。参考文档,我们只需要创建mybatis核心配置文件mybatis-config.xml,mapper.xml以及对应的mapper接口。
1、mybatis-config.xml (使用外部属性文件配置数据源)
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- 引入数据连接参数属性文件 -->
<!-- <properties resource="mysqldb.properties"/> -->
<properties resource="oracledb.properties"/>
<!--设置日志-->
<settings>
<setting name="logImpl" value="STDOUT_LOGGING"/>
</settings>
<!--类型别名:用于写sql文件中入参类型和返回类型的指定 -->
<typeAliases>
<package name="com.cssl.pojo"/>
</typeAliases>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<!--配置数据源,创建Connection连接对象-->
<dataSource type="POOLED">
<!--driver:驱动的内容-->
<property name="driver" value="${driver}"/>
<!--url:连接数据库的url-->
<property name="url" value="${url}"/>
<!--用户名-->
<property name="username" value="${username}"/>
<!--密码-->
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments>
<mappers>
<!--
指定mapper文件的路径
-->
<!-- <mapper resource="com/cssl/mapper/EmpMapper.xml"/> -->
<package name="com.cssl.mapper"/>
</mappers>
</configuration>
2、mapper接口
package com.cssl.mapper;
import java.util.List;
import java.util.Map;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.junit.jupiter.params.ParameterizedTest;
import com.cssl.pojo.Emp;
public interface EmpMapper {
public List<Emp> getAllEmp();
public List<Emp> getByName(Map<String, String> map);
public Emp getEmpById(@Param("no") Integer empno);
}
3、mapper.xml文件
<?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.cssl.mapper.EmpMapper">
<select id="getAllEmp" resultType="com.cssl.pojo.Emp">
select empno,ename as name,job,mgr,hiredate,sal,comm,deptno from emp
</select>
<select id="getByName" parameterType="java.util.Map" resultType="com.cssl.pojo.Emp">
select empno,ename as name,job,mgr,hiredate,sal,comm,deptno from Emp where ename=#{
ename}
</select>
<select id="getEmpById" parameterType="java.lang.Integer" resultType="Emp">
select empno,ename as name,job,mgr,hiredate,sal,comm,deptno from Emp where empno=#{
no}
</select>
</mapper>
4、创建Junit测试类
package com.cssl.test;
import java.io.IOException;
import java.io.InputStream;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.After;
import org.junit.jupiter.api.AfterAll;
import org.junit.jupiter.api.BeforeAll;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import com.cssl.mapper.EmpMapper;
import com.cssl.pojo.Emp;
class JTest {
static SqlSessionFactory ssf = null;
static EmpMapper mapper = null;
static SqlSession session = null;
@BeforeAll
static void beforeAll() {
try {
InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
ssf = new SqlSessionFactoryBuilder().build(inputStream);
System.out.println("创建成功" + ssf);
} catch