在Java中反对类转换异常

时间:2013-10-24 20:56:56

标签: java hibernate intellij-idea

我有一个让我有点疯狂的问题。这是Java方法。

public List<FtpActiveMerchantDTO> getFtpActiveMerchants() {

    String sql = "select m.merchantId, ma.merchantAcctId, m.domain, f.fetchUrl, ma.acctActive, " +
            "f.fieldDelimiter, f.feedType " +
            "from merchant_account ma " +
            "join merchant_ftp_account f on f.merchantAcctId = ma.merchantAcctId " +
            "join merchant m on m.merchantAcctId = ma.merchantAcctId " +
            "where f.fetchUrl is not null and ma.acctActive = 1";

    Query query = currentSession().createSQLQuery(sql);

    List<FtpActiveMerchantDTO> ftpActiveMerchantDTOList = new ArrayList<FtpActiveMerchantDTO>();
    int merchantId, merchantAcctId;
    byte acctActive;
    for (Object rowObject : query.list()) {
        Object[] row = (Object []) rowObject;
        merchantId = ((BigDecimal) row[0]).intValue();
        merchantAcctId = ((BigDecimal) row[1]).intValue();
        acctActive = ((BigDecimal) row[4]).byteValue();
        ftpActiveMerchantDTOList.add(new FtpActiveMerchantDTOBuilder().withMerchantId(merchantId)
                .withMerchantAcctId(merchantAcctId).withDomain((String) row[2])
                .withFetchUrl((String) row[3]).withAcctActive(acctActive > 0)
                .withFieldDelimiter(row[5].toString()).withFeedType((String) row[6]).build());
    }

    return ftpActiveMerchantDTOList;
}

当我使用此处显示的代码运行我的服务时,我得到了

$ curl -X GET http://localhost:8080/merchants/ftpActive
{"responseData":null,"errorData":[{"code":500,"detailMessage":"","message":"java.lang.Byte cannot be cast to java.math.BigDecimal"}],"debugData":null}

错误发生在分配了acctActive的行。当我修改这条线时:

acctActive = (Byte) row[4];

然后服务按预期工作。但接着我的集成测试(从IntelliJ中运行)

private void whenFetchingFtpActiveMerchants() {
    openAndBindSession();
    ftpActiveMerchantDTOList = merchantDAO.getFtpActiveMerchants();
    flushAndCloseSession();
}

失败,出现此错误:

java.lang.ClassCastException: java.math.BigDecimal cannot be cast to java.lang.Byte
at com.pronto.mpds.dal.MerchantDAOImpl.getFtpActiveMerchants(MerchantDAOImpl.java:143)
at com.pronto.mpds.dal.MerchantDAOIT.whenFetchingFtpActiveMerchants(MerchantDAOIT.java:96)
at com.pronto.mpds.dal.MerchantDAOIT.testFtpActiveMerchants(MerchantDAOIT.java:44)
...

db表中的字段是tinyint(4)。为什么db查询的结果“期望”是BigDecimal?是否有某种默认数据类型?我知道我没有在任何地方配置它。

1 个答案:

答案 0 :(得分:0)

乍一看,集成测试的数据库模式与生产测试的数据库模式不同,因此类型不匹配。