JPA默認(rèn)值設(shè)置沒有效果的解決
問題:默認(rèn)值設(shè)置沒有效果
springboot項(xiàng)目的JPA數(shù)據(jù)庫表的類添加默認(rèn)值,有2種方法
1、@Column(columnDefinition = "varchar(35) default ‘12345‘ ")
2、@ColumnDefault(“12345”)
要求:設(shè)置img字段默認(rèn)值為/imgs/defunct.png
依賴
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.46</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.16.20</version>
</dependency>
映射類
@Data
@NoArgsConstructor
@AllArgsConstructor
@DynamicInsert
@DynamicUpdate
@Entity(name = "tbl_user")
public class UserInfo {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@ColumnDefault("\\imgs\\defunct.png")
private String img;
@ColumnDefault("0")
private Integer studyBegin;
}
數(shù)據(jù)庫設(shè)計(jì)表字段

只有studyBegin默認(rèn)值設(shè)置為0,img的默認(rèn)值設(shè)置不成功。
解決辦法
把
@ColumnDefault("/imgs/defunct.png")
改為
@Column(columnDefinition = “varchar(255) default ‘/imgs/defunct.png'”)
效果

JPA為字段設(shè)置默認(rèn)值
在使用JPA時(shí),如果需要為屬性設(shè)置默認(rèn)值,很自然的,你可能會(huì)想到用下面的方式。
@Column(name="state",columnDefinition="tinyint default 0") private Integer state=0;
但很不幸的是,這種方案有時(shí)候并不可行,原因在于columnDefinition是在創(chuàng)建表的時(shí)候使用的,如果你的表不是自動(dòng)生成的。
那我們又需要為屬性添加默認(rèn)值,該怎么辦呢,其實(shí)很簡單,就直接為屬性賦值就可以了。
private Integer state=0;
有時(shí)候,看起來很復(fù)雜的問題,其實(shí)換個(gè)角度思考,其實(shí)就會(huì)變得很簡單。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于SpringCloud的微服務(wù)結(jié)構(gòu)及微服務(wù)遠(yuǎn)程調(diào)用
Spring Cloud 是一套完整的微服務(wù)解決方案,基于 Spring Boot 框架,準(zhǔn)確的說,它不是一個(gè)框架,而是一個(gè)大的容器,它將市面上較好的微服務(wù)框架集成進(jìn)來,從而簡化了開發(fā)者的代碼量,需要的朋友可以參考下2023-05-05
Spring Boot + Jpa(Hibernate) 架構(gòu)基本配置詳解
本篇文章主要介紹了Spring Boot + Jpa(Hibernate) 架構(gòu)基本配置詳解,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05
IntelliJ IDEA Tomcat控制臺(tái)中文亂碼問題的四種解決方案
這篇文章主要給大家分享了4種方法完美解決IntelliJ IDEA Tomcat控制臺(tái)中文亂碼問題,文中有詳細(xì)的圖文介紹,對(duì)我們的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2023-08-08
java判斷今天,昨天,前天,不能用秒間隔的簡單實(shí)例
下面小編就為大家?guī)硪黄猨ava判斷今天,昨天,前天,不能用秒間隔的簡單實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-03-03
SpringBoot整合Spring?Boot?Admin實(shí)現(xiàn)服務(wù)監(jiān)控的方法
這篇文章主要介紹了SpringBoot整合Spring?Boot?Admin實(shí)現(xiàn)服務(wù)監(jiān)控,內(nèi)容包括Server端服務(wù)開發(fā),Client端服務(wù)開發(fā)其中Spring Boot Admin還可以對(duì)其監(jiān)控的服務(wù)提供告警功能,如服務(wù)宕機(jī)時(shí),可以及時(shí)以郵件方式通知運(yùn)維人員,感興趣的朋友跟隨小編一起看看吧2022-03-03
SpringBoot+Vue項(xiàng)目新手快速入門指南
最近剛剛做了一個(gè)基于vue+springboot的系統(tǒng),于是基于這點(diǎn),對(duì)遇到的一些問題進(jìn)行一些配置的匯總,下面這篇文章主要給大家介紹了關(guān)于SpringBoot+Vue項(xiàng)目新手快速入門的相關(guān)資料,需要的朋友可以參考下2022-06-06
springboot Rabbit MQ topic 配置文件綁定隊(duì)列和交換機(jī)的
本文詳細(xì)講解了在SpringBoot中使用RabbitMQ進(jìn)行隊(duì)列與交換機(jī)的綁定方法,包括創(chuàng)建交換機(jī)、隊(duì)列和綁定它們的步驟,以及如何發(fā)送和接收消息,適用于開發(fā)高并發(fā)系統(tǒng),如秒殺系統(tǒng)等2024-09-09
springboot整合mqtt實(shí)現(xiàn)消息訂閱和推送功能
mica-mqtt-client-spring-boot-starter是一個(gè)方便、高效、可靠的MQTT客戶端啟動(dòng)器,適用于需要使用MQTT協(xié)議進(jìn)行消息通信的Spring Boot應(yīng)用程序,這篇文章主要介紹了springboot整合mqtt實(shí)現(xiàn)消息訂閱和推送功能,需要的朋友可以參考下2024-02-02

