我有一个具有数据类型 joda.money 属性的类。 如何将此属性映射到 mysql 中。
我的类(class)是:
@Table(name="products") public class Product(){ @Column(name="name") String name; @Column(name="money") Money money; }
我正在使用 Spring Hibernate
谁能告诉我如何将这个模型存储到mysql中吗?
最佳答案
您在这里有更多选择。
- 您可以创建两个字段来代表 Joda 的
金钱
。BigDecimal
表示金额,String
表示货币。然后创建 transient 合成字段Money
并在 getter 中创建它(参见下面的示例)。 - 您可以实现自己的
UserType
并自行提供序列化/反序列化。请参阅 javadoc UserType和文档 Custom types using org.hibernate.usertype.UserType 。看看thisCompositeUserType
的实现。 您可以包含Jadira Usertypes 项目为 Hibernate 提供 Joda
Money
支持(反正我从来没有尝试过)@Entity @Table(name = "products") public class Product { @Basic @Column private BigDecimal amount; @Basic @Column private String currency; private transient Money money; public Money getMoney() { if (money == null) { money = Money.of(CurrencyUnit.of(currency), amount); } return money; } }
关于hibernate - 如何在mysql中存储joda.money,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18379590/