gpt4 book ai didi

hibernate - 如何在mysql中存储joda.money

转载 作者:行者123 更新时间:2023-12-02 21:52:10 30 4
gpt4 key购买 nike

我有一个具有数据类型 joda.money 属性的类。如何将此属性映射到 mysql 中。

我的类(class)是:

@Table(name="products") public class Product(){ @Column(name="name") String name; @Column(name="money") Money money; }

我正在使用 Spring Hibernate

谁能告诉我如何将这个模型存储到mysql中吗?

最佳答案

您在这里有更多选择。

  1. 您可以创建两个字段来代表 Joda 的金钱BigDecimal 表示金额,String 表示货币。然后创建 transient 合成字段 Money 并在 getter 中创建它(参见下面的示例)。
  2. 您可以实现自己的UserType并自行提供序列化/反序列化。请参阅 javadoc UserType和文档 Custom types using org.hibernate.usertype.UserType 。看看this CompositeUserType 的实现。
  3. 您可以包含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/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com