gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-02 04:53:36 32 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 的MoneyBigDecimal 表示金额,String 表示货币。然后创建 transient 合成字段 Money 并在 getter 中创建它(参见下面的示例)。
  2. 您可以实现自己的UserType 并自行提供序列化/反序列化。参见 javadoc UserType和文档 Custom types using org.hibernate.usertype.UserType .看看this CompositeUserType 的实现。
  3. 您可以包含 Jadira为 Hibernate 提供 Joda Money 支持的 Usertypes 项目(反正我从来没有尝试过)

    @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/

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