首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >设置缺省原语布尔值

设置缺省原语布尔值
EN

Stack Overflow用户
提问于 2022-07-09 18:42:59
回答 1查看 249关注 0票数 0

我有一个处理数据库的基本SpringBoot/Hibernate应用程序。Oracle表中有一列表示布尔值。在数据库级别,它是这样表示的-- P_IND CHAR(1 BYTE) DEFAULT 'N' NOT NULL

在实体层面,我把它映射成这样-

代码语言:javascript
运行
复制
@Column(name = "P_IND")
@Type(type = "yes_no")
private boolean ind;

在创建新记录时,缺省值需要是'N‘,这与预期的效果相同。现在,缺省值需要是true (数据库中的‘Y’)。我可以这样做

( a) private boolean ind = true;

或添加此注释

( b) @ColumnDefault("true")

  1. 不是更有利的,因为您可以创建/持久化具有真/假值的实体?
  2. 将允许同时创建这两个实体(ind是原始布尔值),如果是,注释是否是更好的实现方法?
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-07-09 23:25:38

他们做两件不同的事。

@ColumnDefault是Hibernate ORM特定的注释(不是JPA)。它标识Hibernate在启动时生成模式时将在列定义中使用的默认值。这意味着这只在Hibernate创建列时使用。

代码语言:javascript
运行
复制
private boolean ind = true;

使用原语类型意味着在持久化或更新期间,值始终是truefalse (我认为在Java中默认为false)。因此,@ColumnDefault并不重要(除非您在没有Hibernate ORM的情况下运行自定义插入查询)。

如果将类型更改为Boolean,则ind可以为null。这意味着插入时使用的默认值将是创建列时使用的默认值。如果您使用Hibernate ORM创建了数据库,那么它就是@ColumnDefault中的值。

不管怎么说,看来你两者都需要。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72923835

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档