mybatis源码详解


1、什么是mybatis

Mybatis是一个开源、轻量级的数据持久化框架,是 JDBC 和 Hibernate 的替代方案。MyBatis内部封装了 JDBC,简化了加载驱动、创建连接、创建 statement 等繁杂的过程,开发者只需要关注 SQL 语句本身。

2、mybatis项目搭建

项目的搭建我们可以参照官方文档,该项目基于mybatis-3.5.10,不加入Spring整合。参考文档,我们只需要创建mybatis核心配置文件mybatis-config.xmlmapper.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().
  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值