java handler null_java – 带有MyBatis TypeHandler的Null对象模式

我在发布问题后立即看到了解决方案.在

BaseTypeHandler代码:

[...]

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.

EDITED(以下是quux00的评论):当然,我们可以覆盖BaseTypeHandler的getResult方法,因为它的方法setParameters提供的功能很有用.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值