使用Hibernate中的注释定义默认列值

时间:2015-01-23 10:15:03

标签: java hibernate ddl

我知道这里有很多关于SO和网络的问题,但是所有答案建议使用columnDefinition这是特定于数据库的,因此不适合我,因为我正在研究的系统需要在不同的数据库上运行。

我发现这个hibernate issue有人请求此功能进行注释。该问题已被关闭,称another issue将涵盖该功能。第二个问题显然添加了注释@Generated以及其他一些注释,但我找不到任何关于如何使用这些新注释定义默认列值的文档。

所以我的问题是:有谁知道如何使用注释定义默认列值(而不是使用columnDefinition)?

编辑:进一步澄清我的问题:当我添加一个新的非空列时,我需要Hibernate来更新现有的模式(将新列添加到相应的表中)。但由于该列为非null,因此数据库无法在未指定默认值的情况下创建列(如果表中已存在某些行)。所以我需要指示Hibernate发出以下DDL语句:ALTER TABLE my_table ADD COLUMN new_column VARCHAR(3) DEFAULT 'def',但它必须独立于使用的数据库。

2 个答案:

答案 0 :(得分:15)

我认为你不需要任何文档,java文档是自我解释的。 如果我理解正确,您需要一种方法来为字段设置默认值。如果是,请参阅以下代码段。

@Entity
@Table(name = "my_entity")
public class SomeEntity extends BaseEntity {

public static final class MyValueGenerator implements
        ValueGenerator<String> {
    @Override
    public String generateValue(Session session, Object owner) {
        return "This is my default name";
    }
}

@Basic
@Column(name = "name", insertable = true, updatable = true, nullable = false, length = 255)
// This will add a DDL default
@ColumnDefault("'This is my default name'")
// This will add a runtime default.
@GeneratorType(type = MyValueGenerator.class)
private String name;

// getters and setters

}

答案 1 :(得分:7)

以下是为我工作。

@ColumnDefault(&#34;&#39; 0.0&#39;&#34)

@Column(name =&#34; avgRating&#34;)

private float avgRating;