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();
相关推荐
煎饼皮皮侠8 小时前
设计一个分页插件之二【基于mybatis实现分页插件】
mybatis·分页插件
czlczl2002092515 小时前
MyBatis-Plus SQL自动填充字段
sql·tomcat·mybatis
独断万古他化15 小时前
【MyBatis-Plus 进阶】注解配置、条件构造器与自定义 SQL的复杂操作详解
sql·mybatis·mybatis-plus·条件构造器
马猴烧酒.1 天前
【JAVA数据传输】Java 数据传输与转换详解笔记
java·数据库·笔记·tomcat·mybatis
962464i2 天前
mybatis-plus生成代码
java·开发语言·mybatis
小信丶2 天前
@MappedJdbcTypes 注解详解:应用场景与实战示例
java·数据库·spring boot·后端·mybatis
palomua2 天前
MyBatis-Plus实体类新增字段导致存量接口报错问题
数据库·mybatis
椎4952 天前
MybatisPlus插件-简化代码开发
mybatis
root666/2 天前
【Java-后端-Mybatis】DISTINCT 作用
数据库·sql·mybatis
墨雨晨曦882 天前
MyBatis框架篇
java·开发语言·mybatis