中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mybatis-plus查詢源碼的示例分析

發布時間:2022-03-02 14:33:28 來源:億速云 閱讀:302 作者:小新 欄目:開發技術

這篇文章主要介紹mybatis-plus查詢源碼的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

配置詳情

pom.xml

dependency>
     <groupId>com.baomidou</groupId>
     <artifactId>mybatis-plus-boot-starter</artifactId>
     <version>3.4.1</version>
 </dependency>

mapper

public interface GenTableMapper extends BaseMapper<GenTable> {
}

測試類

@RunWith(SpringRunner.class)
@SpringBootTest(classes = GendemoApplication.class)
public class BlockqueueTestDemo {
    @Autowired
    GenTableMapper genTableMapper;
    @Test
    public void test(){
        List<GenTable> genTables = 
        genTableMapper.selectList(new QueryWrapper<>());
    }
}

debug流程

1.發現 genTableMapper 是一個代理對象類型。

mybatis-plus查詢源碼的示例分析

2.進入代理對象MybatisMapperProxy , 調用其invoke 方法,方法的Class類型為BaseMapper.selectList()

mybatis-plus查詢源碼的示例分析

3.其中cachedInvoker()方法會返回一個PlainMethodInvoker ,它重寫了MapperMethodInvoker 接口的invoke()方法

mybatis-plus查詢源碼的示例分析

4.最終會調用MybatisMapperMethodexecute()方法

mybatis-plus查詢源碼的示例分析

public class MybatisMapperMethod {
    public Object execute(SqlSession sqlSession, Object[] args) {
        Object result;
        switch (command.getType()) {
            case INSERT: {
                Object param = method.convertArgsToSqlCommandParam(args);
                result = rowCountResult(sqlSession.insert(command.getName(), param));
                break;
            }
            case UPDATE: {
                Object param = method.convertArgsToSqlCommandParam(args);
                result = rowCountResult(sqlSession.update(command.getName(), param));
                break;
            }
            case DELETE: {
                Object param = method.convertArgsToSqlCommandParam(args);
                result = rowCountResult(sqlSession.delete(command.getName(), param));
                break;
            }
            case SELECT:
                if (method.returnsVoid() && method.hasResultHandler()) {
                    executeWithResultHandler(sqlSession, args);
                    result = null;
                } else if (method.returnsMany()) {
                    result = executeForMany(sqlSession, args);
                } else if (method.returnsMap()) {
                    result = executeForMap(sqlSession, args);
                } else if (method.returnsCursor()) {
                    result = executeForCursor(sqlSession, args);
                } else {
                    Object param = method.convertArgsToSqlCommandParam(args);
                    // TODO 這里下面改了
                    if (IPage.class.isAssignableFrom(method.getReturnType())) {
                        result = executeForIPage(sqlSession, args);
                        // TODO 這里上面改了
                    } else {
                        result = sqlSession.selectOne(command.getName(), param);
                        if (method.returnsOptional()
                            && (result == null || !method.getReturnType().equals(result.getClass()))) {
                            result = Optional.ofNullable(result);
                        }
                    }
                }
                break;
            case FLUSH:
                result = sqlSession.flushStatements();
                break;
            default:
                throw new BindingException("Unknown execution method for: " + command.getName());
        }
        if (result == null && method.getReturnType().isPrimitive() && !method.returnsVoid()) {
            throw new BindingException("Mapper method '" + command.getName()
                + " attempted to return null from a method with a primitive return type (" + method.getReturnType() + ").");
        }
        return result;
    }
}

5.這是經過判斷會進入executeForMany(sqlSession, args)方法,此時方法和參數都顯示出來了。sqlSession的類型是SqlSessionTemplate , 為什么要注意這個 sqlSession的類型?因為SqlSession是一個接口,有很多實現類,有時候我們并不知道到底調用了哪個實現類的selectList()方法,這個時候我們看類型就知道了,就可以進入SqlSessionTemplate類,找到selectList()打上斷點,debug就過來了。

mybatis-plus查詢源碼的示例分析

6.利用同樣的方法,又調用了DefaultSqlSessionselectList()方法。

mybatis-plus查詢源碼的示例分析


7.來到DefaultSqlSessionselectList() 方法中,此時已經進入到mybatis的源碼范圍了。executor的類型是MybatisCachingExecutor

mybatis-plus查詢源碼的示例分析

8.此時要注意MybatisCachingExecutor 代理類的handler是一個Plugin

mybatis-plus查詢源碼的示例分析

mybatis-plus查詢源碼的示例分析

9.因為我使用到了分頁插件,所以會來到com.github.pagehelperPageInterceptor

mybatis-plus查詢源碼的示例分析

10.由MybatisCachingExecutor來執行查詢

mybatis-plus查詢源碼的示例分析

11.MybatisCachingExecutor 委派 BaseExecutor 執行查詢

mybatis-plus查詢源碼的示例分析

mybatis-plus查詢源碼的示例分析

12.最終委派到PreparedStatementHandler來處理

mybatis-plus查詢源碼的示例分析

13.最后由DefaultResultSetHandler來封裝結果集

@Override
  public List<Object> handleResultSets(Statement stmt) throws SQLException {
    ErrorContext.instance().activity("handling results").object(mappedStatement.getId());

    final List<Object> multipleResults = new ArrayList<>();
    int resultSetCount = 0;
    ResultSetWrapper rsw = getFirstResultSet(stmt);
    List<ResultMap> resultMaps = mappedStatement.getResultMaps();
    int resultMapCount = resultMaps.size();
    validateResultMapsCount(rsw, resultMapCount);
    while (rsw != null && resultMapCount > resultSetCount) {
      ResultMap resultMap = resultMaps.get(resultSetCount);
      handleResultSet(rsw, resultMap, multipleResults, null);
      rsw = getNextResultSet(stmt);
      cleanUpAfterHandlingResultSet();
      resultSetCount++;
    }
    String[] resultSets = mappedStatement.getResultSets();
    if (resultSets != null) {
      while (rsw != null && resultSetCount < resultSets.length) {
        ResultMapping parentMapping = nextResultMaps.get(resultSets[resultSetCount]);
        if (parentMapping != null) {
          String nestedResultMapId = parentMapping.getNestedResultMapId();
          ResultMap resultMap = configuration.getResultMap(nestedResultMapId);
          handleResultSet(rsw, resultMap, null, parentMapping);
        }
        rsw = getNextResultSet(stmt);
        cleanUpAfterHandlingResultSet();
        resultSetCount++;
      }
    return collapseSingleResultList(multipleResults);
  }

以上是“mybatis-plus查詢源碼的示例分析”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

乌拉特后旗| 永丰县| 义马市| 平江县| 玛多县| 准格尔旗| 石景山区| 通渭县| 德惠市| 安义县| 柘城县| 宁陵县| 莱西市| 旌德县| 永清县| 临江市| 扶风县| 吉隆县| 嘉禾县| 临汾市| 乐亭县| 鹤山市| 奈曼旗| 淮北市| 宣威市| 宜兰县| 丰镇市| 安化县| 三门峡市| 海城市| 齐齐哈尔市| 凤山市| 葵青区| 财经| 巩留县| 克拉玛依市| 尖扎县| 安顺市| 蚌埠市| 湟源县| 安吉县|