jpa使用注解生成表時(shí)無外鍵問題及解決
jpa注解生成表時(shí)無外鍵
剛?cè)胧謘pringboot時(shí),在使用jpa實(shí)體注解生成表無外鍵。是因?yàn)閖pa不知道使用何種Dialect創(chuàng)建,默認(rèn)沒有外鍵。
在配置文件加上
database-platform: org.hibernate.dialect.MySQL5InnoDBDialect
就好了。
使用jpa自動(dòng)建表不生成外鍵情況
springboot項(xiàng)目搭配的jpa使用時(shí)候,有一對(duì)多的關(guān)系注解,那么自動(dòng)會(huì)生成外鍵。外鍵在有些時(shí)候,會(huì)導(dǎo)致代碼不能走通,我們不想要怎么做。
@ManyToOne @JoinColumn(name="cid")
要使數(shù)據(jù)表中沒有外鍵關(guān)聯(lián)關(guān)系,注意兩點(diǎn)。
情況1
當(dāng)兩邊都有關(guān)聯(lián)關(guān)系字段,1的這端利用@org.hibernate.annotations.ForeignKey(name = “none”),多的那端在JoinColumn中加上
foreignKey = @ForeignKey(name = “none”,value = ConstraintMode.NO_CONSTRAINT)
情況2
當(dāng)只有多的那端有關(guān)聯(lián)字段,一的那段沒有關(guān)聯(lián)字段或者關(guān)聯(lián)字段被@Transient所修飾,請(qǐng)?jiān)诙嗟哪嵌嗽贘oinColumn中加上
foreignKey = @ForeignKey(name = “none”,value = ConstraintMode.NO_CONSTRAINT)
?@ManyToOne ?@JoinColumn(name="cid",foreignKey = @ForeignKey(name = "none",value = ConstraintMode.NO_CONSTRAINT))
最后需要說明的是@org.hibernate.annotations.ForeignKey(name = “none”)這個(gè)注解被廢棄了,所以更新jar包的時(shí)候需要注意下。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Sharding-Jdbc 自定義復(fù)合分片的實(shí)現(xiàn)(分庫(kù)分表)
本文主要介紹了Sharding-Jdbc 自定義復(fù)合分片的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07
Java中Map與JSON數(shù)據(jù)之間的互相轉(zhuǎn)化
我們?cè)陂_發(fā)中難免和JSON打交道,這不小編最近遇到了,需要把一些信息轉(zhuǎn)成JSON字符串,下面這篇文章主要給大家介紹了關(guān)于Java中Map與JSON數(shù)據(jù)之間的互相轉(zhuǎn)化,需要的朋友可以參考下2023-04-04
基于Java實(shí)現(xiàn)簡(jiǎn)單貪吃蛇游戲
這篇文章主要為大家詳細(xì)介紹了基于Java實(shí)現(xiàn)簡(jiǎn)單貪吃蛇,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04
Spring Boot @Scheduled定時(shí)任務(wù)代碼實(shí)例解析
這篇文章主要介紹了Spring Boot @Scheduled定時(shí)任務(wù)代碼實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06
SpringBoot解析@Value注解型解析注入時(shí)機(jī)及原理分析
@Value注解可以用來將外部的值動(dòng)態(tài)注入到Bean中,可以獲取配置文件中的屬性值和通過SpEl表達(dá)式獲取bean的屬性或方法2024-12-12

