Spring管理JDBCTemplate之EmptyResultDataAccessException异常

Spring管理JDBCTemplate之EmptyResultDataAccessException异常)

在使用Spring管理JDBC时,一般使用JdbcDaoSupport类下的JdbcTemplate模板。该模板提供了几个方法:

用于增删改:

update(String sql,Object args)

用于查询:
  1. 查询单列单个数据:queryForObject(String sql,XXX.class)
  2. 查询多列多个数据:queryForMap(String sql)
  3. 查询单行数据:queryForObject(String sql,Object[] args,RowMapper<T> rowMapper)
  4. 查询多行数据:query(String sql,Object[] args,RowMapper<T> rowMapper)

当该JDBC管理模板根据sql语句在数据库中查找不到数据时,会抛出EmptyResultDataAccessException异常,而不是返回null。这是为了避免程序员不对空值进行处理。

此时如果想返回null可以使用try-catch对该异常进行处理:

 public T mySqlMethod() {
      try{
          return this.getJdbcTemplate().queryForObject(sql, new RowMapper<T>() {
              @Override
              public Courier mapRow(ResultSet resultSet, int i) throws SQLException {
                  return "OK";
              }
          });
      }catch (EmptyResultDataAccessException e){
          return null;
      }
  }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值