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

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

王林
發布: 2023-05-03 23:10:09
轉載
1563 人瀏覽過
前言:

解析完全局設定檔後接下來就是解析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介面並註冊

  • #處理解析失敗的<resultMap>標籤

  • #處理解析失敗的<cache-ref>標籤

  • 處理解析失敗的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&#39;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 &#39;" + resource + "&#39;. Cause: " + e, e);
    }
  }
登入後複製
  • 解析Mapper檔案的namespace屬性

  • 解析<cache-ref>標籤,這個標籤是用來引用別的Cache快取

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

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

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

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

  • 解析<select>、<insert>、<update>#解析<select>、<insert>、<update>、#等SQL節點,這些標籤大家一定就熟悉了,就是我們的增刪改查的sql語句,透過XMLStatementBuilder來進行解析,它會先解析<include>標籤,然後解析

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

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

相關標籤:
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
java可以做為web的後端嗎?
來自於 1970-01-01 08:00:00
0
0
0
安裝JAVA
來自於 1970-01-01 08:00:00
0
0
0
無法安裝java
來自於 1970-01-01 08:00:00
0
0
0
求救:JAVA加密的資料PHP解密
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板