拉风的电池 · 院庆 · 工者谈 | ...· 1 月前 · |
任性的小马驹 · 关于下发全国统一更换新版普通发票的通告的通知· 2 月前 · |
爱吹牛的钥匙 · 西班牙超级杯:马德里竞技不敌毕尔巴鄂竞技-新 ...· 11 月前 · |
爱跑步的山寨机 · 漫画点评|《孤鸿》累计人气突破3100万!正 ...· 1 年前 · |
我有一个处理数据库的基本SpringBoot/Hibernate应用程序。Oracle表中有一列表示布尔值。在数据库级别,它是这样表示的--
P_IND CHAR(1 BYTE) DEFAULT 'N' NOT NULL
。
在实体层面,我把它映射成这样-
@Column(name = "P_IND")
@Type(type = "yes_no")
private boolean ind;
在创建新记录时,缺省值需要是'N‘,这与预期的效果相同。现在,缺省值需要是
true
(数据库中的‘Y’)。我可以这样做
( a)
private boolean ind = true;
或添加此注释
( b)
@ColumnDefault("true")
ind
是原始布尔值),如果是,注释是否是更好的实现方法?
他们做两件不同的事。
@ColumnDefault
是Hibernate ORM特定的注释(不是JPA)。它标识Hibernate在启动时生成模式时将在列定义中使用的默认值。这意味着这只在Hibernate创建列时使用。
private boolean ind = true;
使用原语类型意味着在持久化或更新期间,值始终是
true
或
false
(我认为在Java中默认为
false
)。因此,
@ColumnDefault
并不重要(除非您在没有Hibernate ORM的情况下运行自定义插入查询)。
如果将类型更改为
Boolean
,则
ind
可以为null。这意味着插入时使用的默认值将是创建列时使用的默认值。如果您使用Hibernate ORM创建了数据库,那么它就是
@ColumnDefault
中的值。
不管怎么说,看来你两者都需要。
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2023 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号: 粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
扫码关注腾讯云开发者
领取腾讯云代金券
拉风的电池 · 院庆 · 工者谈 | 唐少强:善教从游,播种工学_北京大学工学院_北大工学院,力学,固体力学,流体力学,湍流,一般力学,工程计算,有限元,能源,资源,先进制造,工业工程,机器人,航空,航天 1 月前 |
任性的小马驹 · 关于下发全国统一更换新版普通发票的通告的通知 2 月前 |
爱吹牛的钥匙 · 西班牙超级杯:马德里竞技不敌毕尔巴鄂竞技-新华网体育 11 月前 |