hibernate注解设置默认值

一般在网上都会说通过下面这种方式来生成默认值

@Column(name="abc" ,nullable=false,columnDefinition="INT default 0")
private Integer abc;

但这种方式是编写原生的生成表结构的sql,除了语法要保证正确外,而且类型需要数据库支持才行,并不能自动匹配类型。
其实hibernate提供了专门设置默认值的注解:

@ColumnDefault("0")
private Integer abc;

官方文档demo:
使用Hibernate,您可以使用@ColumnDefault注释为给定的数据库列指定默认值。

示例. @ColumnDefault映射示例

@Entity(name = "Person")
@DynamicInsert
public static class Person {

    @Id
    private Long id;

    @ColumnDefault("'N/A'")
    private String name;

    @ColumnDefault("-1")
    private Long clientId;

    //Getter and setters omitted for brevity

}
CREATE TABLE Person (
  id BIGINT NOT NULL,
  clientId BIGINT DEFAULT -1,
  name VARCHAR(255) DEFAULT 'N/A',
  PRIMARY KEY (id)
)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,443评论 19 139
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 47,251评论 6 342
  • 《我是范雨素》火了,我看了记着采访她的新闻。很多感触。今天想说其中一个让我触动的方面。 提到女儿的教育,她说,教育...
    蓝焰行动阅读 143评论 0 1
  • 不知道从什么时候起。回忆开始变得那么不真实,那些曾经温情的往事,一时间,竟然有了许多陌生的感觉。偶然想起,不禁有些...
    卡蕾妹妹阅读 462评论 1 10
  • 【姓名】徐伟 【坐标】浙江温州 【编号】7班-488 【公众号】酒歌爱读书 【标签】双日更、持续践行微习惯 【爱好...
    徐伟_1226阅读 374评论 2 4

友情链接更多精彩内容