jonesleon 2010-08-01 04:51
浏览 439
已采纳

加载Hibernate实体BigDecimal属性,不等于预定的BigDecimal对象

我将Hibernate 实战源代码后端数据库从hsql改成mysql,运行testng测试,auction.test.basic.MapAndXMLRepresentation类
workWithMaps方法有如下加载过程:
[code="java"]Map loadedItem =(Map) session.load("ItemEntity",(Serializable)((Map)storedData.get("item1")).get("id") );
assert (loadedItem.get("initialPrice")).equals(new BigDecimal(99));[/code]

测试时断言失败,我将它的映射文件,类、集合、关联映射均设置lazy="false",仍然断言失败。甚至改成:
[code="java"]Map loadedItem =(Map) session.get("ItemEntity",(Serializable)((Map)storedData.get("item1")).get("id") );
assert (loadedItem.get("initialPrice")).equals(new BigDecimal(99));[/code]
也断言失败,后来改成:
[code="java"]Map loadedItem =(Map) session.get("ItemEntity",(Serializable)((Map)storedData.get("item1")).get("id") );
BigDecimal bd = (BigDecimal)loadedItem.get("initialPrice");

assert bd.intValue() == 99; [/code]
测试断言通过,将映射中的lazy="false"也通过。不明白为何
[code="java"]assert (loadedItem.get("initialPrice")).equals(new BigDecimal(99));[/code]
不能通过,有谁能解释一下?

  • 写回答

1条回答 默认 最新

  • iteye_17757 2010-08-01 08:49
    关注

    BigDecimal,是否由于其属性scale或精度不同

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部