首頁 > 軟體

MyBatis實現註冊及獲取Mapper

2022-03-29 19:00:02

一、搭建環境

1.1 pom.xml

 <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
        </dependency>

1.2 BlogMapper.java

public interface BlogMapper {
    List<Blog> selectBlog(String id);
}

1.3 BlogMapper.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="mybatis.source.study.BlogMapper">
    <select id="selectBlog" resultType="mybatis.source.study.Blog">
    select * from t_blog where id= #{id}
  </select>
</mapper>

BlogMapper.xml放在resource目錄下與BlogMapper.java包路徑相同的路徑下

1.4 MyBatisDemo.java

public class MyBatisDemo {
    public static void main(String[] args) {
    	//建立資料來源
        DataSource dataSource = getDataSource();
        TransactionFactory transactionFactory = new JdbcTransactionFactory();
        //建立sql執行環境
        Environment environment = new Environment("development", transactionFactory, dataSource);
        //建立mybatis的所有設定
        Configuration configuration = new Configuration(environment);
        //註冊mapper
        configuration.addMapper(BlogMapper.class);
//        configuration.addInterceptor(new PaginationInterceptor());
		//根據設定建立sql對談工廠
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(configuration);
        SqlSession sqlSession = sqlSessionFactory.openSession();
        BlogMapper mapper = sqlSession.getMapper(BlogMapper.class);
        System.out.println(mapper.selectBlog("001"));
    }

    private static DataSource getDataSource() {
        DruidDataSource druidDataSource = new DruidDataSource();
        druidDataSource.setUrl("jdbc:mysql://localhost:3306/demo?characterEncoding=utf-8&serverTimezone=Asia/Shanghai");
        druidDataSource.setUsername("root");
        druidDataSource.setPassword("root");
        return druidDataSource;
    }

二、addMapper詳細分析

2.1 MapperRegistry

這塊就是判斷這個mapper.xml解析過沒有,解析是在 parser.parse();中做的,來看

loadXmlResource();根據xml解析每個mapper介面的方法,將得到的MapperStatement放進了configuration,然後記錄該xml的namespace表示已經處理過。具體呼叫鏈:

loadXmlResource()–>xmlParser.parse()–>configurationElement(parser.evalNode("/mapper"))–> buildStatementFromContext(context.evalNodes(“select|insert|update|delete”))–> buildStatementFromContext(list, null)–>statementParser.parseStatementNode()–>builderAssistant.addMappedStatement–>configuration.addMappedStatement(statement);

parseStatement(method);根據註解解析每個mapper介面的方法,因此xml和註解可以同時使用。但是同一個方法兩者同時使用會報錯

2.2 MapperProxyFactory

放入knownMappers的是MapperProxyFactory,它是一個Mapper代理的工廠,這個工廠提供newInstance方法,產生一個代理類(也就是BlogMapper介面的代理實現類),呼叫BlogMapper所有的方法將在MapperProxy的invoke方法中執行

三、getMapper詳細分析

getMapper會呼叫MapperRegistry的getMapper從knownMappers中獲取代理工廠,再呼叫newInstance方法產生一個代理類MapperProxy。

3.1 MapperProxy

在執行mapper.selectBlog(“001”)時,就會呼叫MapperProxy的invoke方法

根據method(selectBlog)生成對應的MapperMethod,並將MapperMethod放入本地快取。
mapperMethod.execute(sqlSession, args);執行真正的sql邏輯。

3.2 MapperMethod

MapperMethod的構造方法,根據介面資訊、方法資訊、設定資訊得到SqlCommand(sql名稱、型別)、method(方法簽名),方便後續執行命令、處理結果集等。

到此這篇關於MyBatis實現註冊及獲取Mapper的文章就介紹到這了,更多相關MyBatis 註冊及獲取Mapper內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com