1

我有一个问题让我有点发疯。这是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?是否有某种默认数据类型?我知道我没有在任何地方配置一个。

4

1 回答 1

0

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

于 2013-10-25T15:32:43.750 回答