首頁  >  文章  >  Java  >  Java Mybatis的初始化之Mapper.xml映射檔怎麼配置

Java Mybatis的初始化之Mapper.xml映射檔怎麼配置

王林
王林轉載
2023-05-03 23:10:091381瀏覽
前言:

解析完全局設定檔後接下來就是解析Mapper檔了,它是透過XMLMapperBuilder來進行解析的

解析Mapper檔案入口

XMLMapperBuilder的parse()方法:

public void parse() {
    if (!configuration.isResourceLoaded(resource)) {
      configurationElement(parser.evalNode("/mapper"));
      configuration.addLoadedResource(resource);
      bindMapperForNamespace();
    }

    parsePendingResultMaps();
    parsePendingCacheRefs();
    parsePendingStatements();
  }
  • 目前Mapper檔案沒有載入過就呼叫configurationElement()方法解析Mapper檔案

  • 加入到Configuration.loadedResources集合中,防止重複載入

  • 取得Mapper檔案對應的Mapper介面並註冊

  • #處理解析失敗的68a9ca67c267b134c127fbeac6659d23標籤

  • #處理解析失敗的c9f60baecdceda902422ce5608e73ae9標籤

  • 處理解析失敗的SQL語句

重點看XMLMapperBuilder類別的configurationElement()方法

解析Mapper檔案

MLMapperBuilder類別的configurationElement()方法:

private void configurationElement(XNode context) {
    try {
      String namespace = context.getStringAttribute("namespace");
      if (namespace == null || namespace.isEmpty()) {
        throw new BuilderException("Mapper's namespace cannot be empty");
      }
      builderAssistant.setCurrentNamespace(namespace);
      cacheRefElement(context.evalNode("cache-ref"));
      cacheElement(context.evalNode("cache"));
      parameterMapElement(context.evalNodes("/mapper/parameterMap"));
      resultMapElements(context.evalNodes("/mapper/resultMap"));
      sqlElement(context.evalNodes("/mapper/sql"));
      buildStatementFromContext(context.evalNodes("select|insert|update|delete"));
    } catch (Exception e) {
      throw new BuilderException("Error parsing Mapper XML. The XML location is '" + resource + "'. Cause: " + e, e);
    }
  }
  • 解析Mapper檔案的namespace屬性

  • 解析c9f60baecdceda902422ce5608e73ae9標籤,這個標籤是用來引用別的Cache快取

  • 解析62aecd17e676a41d3547c3bf97bb07b0標籤,這個標籤是用來啟用Mybatis的二級快取的,一級快取是預設開啟的,在這個方法裡解析到MapperBuilderAssistant類別完成Cache的創建,保存在Configuration.caches的集合中,集合的key是namespace,值是Cache物件

  • 解析4fb23b7f5df2ee11743b998ba01c37fd標籤,這個標籤已經廢棄了,一般使用parameterType 來定義參數的類別名稱

  • 解析68a9ca67c267b134c127fbeac6659d23標籤,這個標籤是結果映射,它標籤下的所有子標籤解析後保存在ResultMap物件中,具體會解析先取得resultMap中的type,type是結果集映射成的java對象,然後解析resultMap標籤的子標籤,包括3edd161182fff2dd0b855ad5d33f9b63、53384f78b45ee9f1e3082cf378b9c5b4、350c21220441cc2f18e31a24358fe33a、8a69e10c947129bb1dfe1f677169415f等標籤,這些標籤產生ResultMapping對象,然後取得id extends等屬性,建構ResultMapResolver對象,建立ResultMap物件儲存到Configuration.resultMaps集合中

  • #解析sql標籤,這個標籤是用來定義重複的sql片段的,解析出保存在Configuration.sqlFragments中

  • 解析221f08282418e2996498697df914ce4e、3cdbca7b6e47052f0af62aa0d4c6123a、48dd0c1f550330068948da43aff71ce0#解析221f08282418e2996498697df914ce4e、3cdbca7b6e47052f0af62aa0d4c6123a、48dd0c1f550330068948da43aff71ce0、5cc62b85a20462d19109e58cc4ad0bf9#等SQL節點,這些標籤大家一定就熟悉了,就是我們的增刪改查的sql語句,透過XMLStatementBuilder來進行解析,它會先解析dcf91641426a34cf32ecc36140f28baf標籤,然後解析

    d81480a879ba657d83c408e5fa1b948b
  • 標籤,儲存到Configuration.keyGenerators集合中,最後透過LanguageDriver.createSqlSource()方法建立SqlSource對象,建構MappedStatement對象,MappedStatement的sqlSourcesqlsql 記錄語句,sqlCommandType記錄語句的類型,SQL在SQL Configuration.mappedStatements集合中
######

以上是Java Mybatis的初始化之Mapper.xml映射檔怎麼配置的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除