首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带有MyBatis TypeHandler的空对象模式

带有MyBatis TypeHandler的空对象模式
EN

Stack Overflow用户
提问于 2013-02-14 12:09:20
回答 2查看 5.4K关注 0票数 5

我一直试图在MyBatis中定制一个MyBatis,以便对于数据库中的null列,MyBatis返回一个空对象模式的实现,而不是在域类中有一个null

在谷歌搜索帮助之后,我到达了卓越的项目金线莲,即用与我使用的方法完全相同的方法解决这个问题的柯安19,即扩展BaseTypeHandler<T> (是抽象的)。此时,我有一个与在那个树袋熊类似的具体的在那个树袋熊

代码语言:javascript
复制
/**
 * Acts as a factory method to return the appropriate implementation of an Email.
 * Returns a Null object if the email value in the database was null/empty
 */
public class EmailTypeHandler extends BaseTypeHandler<Email> {

  @Override
  public Email getNullableResult(ResultSet rs, String colName) throws SQLException {
    return createEmail(rs.getString(colName));
  }

  @Override
  public Email getNullableResult(ResultSet rs, int colNum) throws SQLException {
    return createEmail(rs.getString(colNum));
  }


  private Email createEmail(String s) {
    System.out.println(s);
    if (s == null || s.equals("")) {
      return new NullEmail();
    } else {
      return new EmailImpl(s);
    }
  }

  @Override
  public Email getNullableResult(CallableStatement arg0, int arg1) throws SQLException {
    return null;
  }

  @Override
  public void setNonNullParameter(PreparedStatement ps, int colNum,
                                  Email e, JdbcType t) throws SQLException {
  }
}

不幸的是,作者(midpeter444)似乎面临着同样的问题:当DB中的值为null时,仍然返回null,而不是在具体的TypeHandler中构建的对象。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-02-14 12:13:59

我刚发完这个问题就看到了解决办法。在BaseTypeHandler代码中:

代码语言:javascript
复制
[...]
  public T getResult(ResultSet rs, String columnName) throws SQLException {
    T result = getNullableResult(rs, columnName);
    if (rs.wasNull()) {
      return null;
    } else {
      return result;
    }
  }

  public T getResult(ResultSet rs, int columnIndex) throws SQLException {
    T result = getNullableResult(rs, columnIndex);
    if (rs.wasNull()) {
      return null;
    } else {
      return result;
    }
  }

  public T getResult(CallableStatement cs, int columnIndex) throws SQLException {
    T result = getNullableResult(cs, columnIndex);
    if (cs.wasNull()) {
      return null;
    } else {
      return result;
    }
  }

  public abstract void setNonNullParameter(PreparedStatement ps, int i, T parameter, JdbcType jdbcType) throws SQLException;

  public abstract T getNullableResult(ResultSet rs, String columnName) throws SQLException;

  public abstract T getNullableResult(ResultSet rs, int columnIndex) throws SQLException;

  public abstract T getNullableResult(CallableStatement cs, int columnIndex) throws SQLException;
[...]

显然,当数据库中的值为null时,BaseTypeHandler将返回null,就像在这种情况下cs.WasNull()true一样。因此,解决方案是创建一个具体的TypeHandler,返回批准的实现(在本例中,当数据库中的值为null时,NullObject实现),而不对BaseTypeHandler进行子类化。

编辑的(折叠Quux00的注释):当然,我们可以重写BaseTypeHandlergetResult方法,因为它的方法setParameters提供的功能可能很有用。

票数 3
EN

Stack Overflow用户

发布于 2016-02-25 16:08:11

谢谢你的回答!它帮助我理解我的问题和如何克服它。我希望结果永远不会是空的。

通过发布BaseTypeHandler的代码,它将确认是否返回null取决于ResultSet.wasNull,而不是取决于从getNullableResult返回的结果本身。因此,我在BaseTypeHandler的具体子类中重写了BaseTypeHandler。在getResult的自定义实现中,调用super.getResult,然后检查null。以下是一个例子:

代码语言:javascript
复制
public Money getResult ( ResultSet rs, String columnName ) throws SQLException
{
    Money result = super.getResult ( rs, columnName );
    return result == null ? Money.ZERO : result;
}

public Money getResult ( ResultSet rs, int columnIndex ) throws SQLException
{
    Money result = super.getResult ( rs, columnIndex );
    return result == null ? Money.ZERO : result;
}

public Money getResult ( CallableStatement cs, int columnIndex ) throws SQLException
{
    Money result = super.getResult ( cs, columnIndex );
    return result == null ? Money.ZERO : result;
}
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14874547

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档