MyBatis主要的类层次结构(Mybatis工具类)

MyBatis主要的类层次结构

每一个MyBatis的应用程序都以一个SqlSessionFactory 对象的实例为核心 。

SqlSessionFactory对象的实例可以通过SqlSessionFactoryBuilder对象来获得 。

SqlSessionFactoryBuilder对象可以从 XML 配置文件中构建 SqlSessionFactory对象。

java 复制代码
package org.example.utils;

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 java.io.IOException;
import java.io.InputStream;

public class MybatisUtil {
    private static SqlSessionFactory sqlSessionFactory;
    static {
        try {
            InputStream in = Resources.getResourceAsStream("mybatis-config.xml");
            sqlSessionFactory = new SqlSessionFactoryBuilder().build(in);
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
    public static SqlSession getSqlSession() {
        return sqlSessionFactory.openSession();
    }
}

通过SqlSessionFactory对象,可以获得SqlSession的实例。

SqlSession 对象完全包含以数据库为背景的所有执行 SQL 操作的方法。你可以用 SqlSession 实例来直接执行已映射的 SQL 语句 。

第一个MyBatis程序

创建实体类User和映射器接口
MyBatis中使用Mapper接口的具体要求:

Mapper接口的全限定名为映射文件的namespace的值

Mapper接口的方法名称和映射文件中定义的每个sql的id相同

Mapper接口的方法参数和映射文件中定义每个sql的parameterType类型相同 Mapper接口的方法返回的单个对象类型和映射文件中定义的每个sql的resultType类型相同

创建MyBatis的主配置文件mybatis.xml

创建MyBatis的主配置文件mybatis.xml 在工程中新建Source Folder命名为resources来专门存放MyBatis的主配置文件,在resources中新建XML File命名为mybatis.xml

创建MyBatis的SQL映射XML文件

创建MyBatis的SQL映射XML文件,并且映射文件要同刚才创建的映射器接口在同一包中,与映射器接口命名也相同,所以映射文件名为UserMapper.xml

注意:要将映射文件关联到主配置文件

将SQL映射文件与主配置文件进行关联
html 复制代码
<?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> 
    <environments default="development"> 
        <!-- 事务和数据源 -->
    </environments> 
    <mappers> 
        <mapper resource="org/mybatis/example/BlogMapper.xml"/>    
    </mappers> 
</configuration>

映射器(mappers)用来配置多个映射文件的位置, 有多种配置方式。

html 复制代码
<!-- 使用相对于类路径的资源引用 --> 
<mapper resource="org/mybatis/builder/AuthorMapper.xml"/>
 
<!-- 使用映射器接口的完全限定类名 --> 
<mapper class="org.mybatis.builder.AuthorMapper"/> 

<!-- 将包内的映射器接口全部注册为映射器 --> 
<package name="org.mybatis.builder"/>
编写代码进行测试
java 复制代码
SqlSession session = MyBatisUtil.openSqlSession();
List<User> users = session.selectList("com.mybatis.mapper.UserMapper.selectAllUsers");
for(User u : users) {
    System.out.println(u);
}
session.close();
相关推荐
HeyZoeHey1 天前
Mybatis执行sql流程(一)
java·sql·mybatis
青川入梦1 天前
MyBatis极速通关上篇:Spring Boot环境搭建+用户管理实战
java·开发语言·mybatis
33255_40857_280591 天前
掌握分页艺术:MyBatis与MyBatis-Plus实战指南(10年Java亲授)
java·mybatis
勿在浮沙筑高台2 天前
无法获取实体类com.example.springdemo2.entity.po.UserPO对应的表名!
java·spring boot·mybatis
柯南二号2 天前
【Java后端】MyBatis-Plus 原理解析
java·开发语言·mybatis
Easocen2 天前
Mybatis学习笔记(五)
笔记·学习·mybatis
qq_三哥啊3 天前
【IDEA】设置Debug调试时调试器不进入特定类(Spring框架、Mybatis框架)
spring·intellij-idea·mybatis
柯南二号3 天前
【Java后端】Spring Boot 集成 MyBatis-Plus 全攻略
java·spring boot·mybatis
记忆不曾留3 天前
Mybatis 源码解读-SqlSession 会话源码和Executor SQL操作执行器源码
mybatis·二级缓存·sqlsession会话·executor执行器·一级缓存localcache
昵称为空C4 天前
SpringBoot 实现DataSource接口实现多租户数据源切换方案
后端·mybatis