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