首頁 > 軟體

Mybatis的型別轉換介面TypeHandler

2022-08-09 18:00:42

前言:

mybatis可以實現jdbc型別和java型別之間的轉換,具體來說有一個型別轉換器的介面

型別處理器介面TypeHandler

public interface TypeHandler<T> {

  void setParameter(PreparedStatement ps, int i, T parameter, JdbcType jdbcType) throws SQLException;

  /**
   * @param columnName Colunm name, when configuration <code>useColumnLabel</code> is <code>false</code>
   */
  T getResult(ResultSet rs, String columnName) throws SQLException;

  T getResult(ResultSet rs, int columnIndex) throws SQLException;

  T getResult(CallableStatement cs, int columnIndex) throws SQLException;

}

型別處理器BaseTypeHandler

jdbc型別轉為java型別

BaseTypeHandler實現了TypeHandler介面,實現了setParameter()方法:

@Override
  public void setParameter(PreparedStatement ps, int i, T parameter, JdbcType jdbcType) throws SQLException {
    if (parameter == null) {
      if (jdbcType == null) {
        throw new TypeException("JDBC requires that the JdbcType must be specified for all nullable parameters.");
      }
      try {
        ps.setNull(i, jdbcType.TYPE_CODE);
      } catch (SQLException e) {
        throw new TypeException("Error setting null for parameter #" + i + " with JdbcType " + jdbcType + " . "
              + "Try setting a different JdbcType for this parameter or a different jdbcTypeForNull configuration property. "
              + "Cause: " + e, e);
      }
    } else {
      try {
        setNonNullParameter(ps, i, parameter, jdbcType);
      } catch (Exception e) {
        throw new TypeException("Error setting non null for parameter #" + i + " with JdbcType " + jdbcType + " . "
              + "Try setting a different JdbcType for this parameter or a different configuration property. "
              + "Cause: " + e, e);
      }
    }
  }

這個方法中就是設定PreparedStatement的引數,也是引數繫結,將jdbcType轉為Java型別,setNonNullParameter是抽象方法,根據不同的引數型別有不同的類實現了這個方法,比如

LongTypeHandler實現的setNonNullParameter()方法:

@Override
  public void setNonNullParameter(PreparedStatement ps, int i, Long parameter, JdbcType jdbcType)
      throws SQLException {
    ps.setLong(i, parameter);
  }

java型別轉為jdbc型別

BaseTypeHandler的getResult()方法:

@Override
  public T getResult(CallableStatement cs, int columnIndex) throws SQLException {
    try {
      return getNullableResult(cs, columnIndex);
    } catch (Exception e) {
      throw new ResultMapException("Error attempting to get column #" + columnIndex + " from callable statement.  Cause: " + e, e);
    }
  }

方法也比較簡單,直接呼叫了getNullableResult抽象類,功能就是從ResultSet中獲取資料,把Java型別轉換為JdbcType型別,比如LongTypeHandler實現的getNullableResult():

@Override
  public Long getNullableResult(ResultSet rs, String columnName)
      throws SQLException {
    long result = rs.getLong(columnName);
    return result == 0 && rs.wasNull() ? null : result;
  }

通過原始碼分析我們知道了TypeHandler介面的作用就是用來實現型別轉換的,mybatis在初始化的時候就獲取TypeHandler,然後建立TypeHandler範例註冊到TypeHandlerRegistry中,由TypeHandlerRegistry來進行管理這些範例,下篇文章中我們介紹一下TypeHandlerRegistry這個類

總結

文章講了Mybatis的型別轉換介面TypeHandler和它的實現類BaseTypeHandler,型別轉換介面顯然就是實現jdbc型別和java型別之間的轉換,同時分析了BaseTypeHandler的setParameter()方法和getResult()方法,getNullableResult是抽象類,具體方法由其他實現類進行實現。

到此這篇關於Mybatis的型別轉換介面TypeHandler的文章就介紹到這了,更多相關Mybatis型別轉換內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


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