java - 如何在 Hibernate 中序列化集合属性?

标签 java hibernate orm mapping

免责声明:我对 Java 开发完全陌生。我已经做过很多 C# 和一些 NHibernate,但是 @Attributes 和 get/set 方法的世界对我来说完全陌生。

问题:我有一个非常简单的持久对象

@Entity
@Table(name = "ADMIN_SETTINGS")
public class AdminSettings extends ClientEntity {
    @Column(name = "SAMPLE_ID_PREFIX")
    private String sampleIdPrefix;
    @Column(name = "USE_24_Hr_CLOCK")
    private Boolean use24hrClock;

    private Integer[] FieldsForSampleBoxView;
 ...

映射我遇到的最后一个字段。它是一个最多包含 3 个整数的简单列表。我不需要一对多表,不需要聚合它,我只需要将集合序列化到数据库中的字段。理想情况下是通过人类可读的东西,但老实说,我不在乎。

我该如何绘制这个 map ?

最佳答案

如果最多包含3个整数,为什么不将这三个整数存储在三列中呢?这至少会被标准化并且可查询。如果没有,那么只需使用持久化的 String 属性,并在 getter 中解析该字符串并在 setter 中转换为字符串:

@Column(FIELDS_FOR_SAMPLE_VIEW_BOX)
private String fieldsForSampleViewBox;

public void setFieldsForSampleViewBox(Integer[] array) {
    StringBuilder b = new StringBuilder();
    for (int i = 0; i < array.length; i++) {
        if (array[i] != null) {
            b.append(array[i]);
        }
        if (i < array.length - 1) {
            b.append(',');
        }
    }
    fieldsForSampleViewBox = b.toString();
}

public Integer getFieldsForSampleViewBox() {
    if (fieldsForSampleViewBox == null || fieldsForSampleViewBox.length() == 0) {
        return new Integer[0];
    }
    String[] strings = fieldsForSampleViewBox.split(",");
    Integer[] result = new Integer(strings.length());
    for (int i = 0; i < strings.length(); i++) {
        if (!strings[i].equals("") {
            result[i] = Integer.valueOf(strings[i]);
        }
    }
    return result;
}

您还可以在 Integer 数组上使用 @Lob 注释或 @Type(type="serializing") 注释,但随后将使用 native Java 序列化,并且它更脆弱且不可读。

关于java - 如何在 Hibernate 中序列化集合属性?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8407274/

相关文章:

java - 可以使用静态属性在应用程序中移动数据吗?

java - Ignite cursor.getAll() 需要很长时间来检索数据

java - mybatis 插入带有列表的嵌套 pojo

java - 将监听器添加到 hibernate session

java - 使用 JPA 查找订单的总价

python - SQLALchemy 动态 filter_by

java - 在 SQLite 中使用 long 插入数据时出现问题始终返回 -1

oracle - 如果值是由触发器生成的,该如何注释Id列?

java - 从事务测试中查看数据 - Hibernate + Spring + MySQL

performance - ColdFusion ORM 的最佳实践