色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Springboot JPA 枚舉Enum類型存入到數(shù)據(jù)庫(kù)的操作

瀏覽:2日期:2023-03-26 15:33:32

1、使用JPA 的@Enumerated 注解 ,可以直接將Enum映射到數(shù)據(jù)庫(kù)中。

但是value的值只有兩種方式選擇,一種是使用枚舉的序號(hào)映射,一種是枚舉的名稱來(lái)映射。

public enum EnumType { /** Persist enumerated type property or field as an integer. */ ORDINAL, /** Persist enumerated type property or field as a string. */ STRING}

如果想存入枚舉中的自定義的值,則需要實(shí)現(xiàn)AttributeConverter接口

2、實(shí)現(xiàn)AttributeConverter接口方式

/** * @param <DB> : 保存到數(shù)據(jù)庫(kù)的數(shù)據(jù)類型 * @author peter * date: 2019-05-15 16:57 **/public interface PersistEnum2DB<DB> { DB getData();}

import javax.persistence.AttributeConverter;/** * @param <ATTR> 實(shí)體類中枚舉的類型,需實(shí)現(xiàn){@link PersistEnum2DB} 接口 * @param <DB> 保存到數(shù)據(jù)庫(kù)的數(shù)據(jù)類型 * @author peter * date: 2019-05-15 16:59 */public abstract class AbstractEnumConverter<ATTR extends Enum<ATTR> & PersistEnum2DB<DB>, DB> implements AttributeConverter<ATTR, DB> { private final Class<ATTR> clazz; public AbstractEnumConverter(Class<ATTR> clazz) { this.clazz = clazz; } @Override public DB convertToDatabaseColumn(ATTR attribute) { return attribute != null ? attribute.getData() : null; } @Override public ATTR convertToEntityAttribute(DB dbData) { if (dbData == null) return null; ATTR[] enums = clazz.getEnumConstants(); for (ATTR e : enums) { if (e.getData().equals(dbData)) { return e; } } throw new UnsupportedOperationException('枚舉轉(zhuǎn)化異常。枚舉【' + clazz.getSimpleName() + '】,數(shù)據(jù)庫(kù)庫(kù)中的值為:【' + dbData + '】'); }}使用方式

import com.tourcoo.parking.enums.convert2db.AbstractEnumConverter;import com.tourcoo.parking.enums.convert2db.PersistEnum2DB;/** * @author peter * create: 2019-05-15 14:33 **/public enum PayStatus implements PersistEnum2DB<Integer> { NONPAY(0, '未支付'), PAID(1, '已支付'); private int code; private String msg; PayStatus(int code, String msg) { this.code = code; this.msg = msg; } public int getCode() { return code; } public String getMsg() { return msg; } @Override public Integer getData() { return code; } public static class Converter extends AbstractEnumConverter<PayStatus, Integer> { public Converter() { super(PayStatus.class); } }}

//支付狀態(tài) @Convert(converter = PayStatus.Converter.class) private PayStatus payStatus;

補(bǔ)充: SpringBoot | Jpa 將Java枚舉映射為基本值類型

解決方法之一:

使用實(shí)體屬性類型轉(zhuǎn)換器AttributeConverter

場(chǎng)景假設(shè):

在代碼中使用枚舉類來(lái)映射用戶性別(如下代碼所示),在數(shù)據(jù)庫(kù)中使用字符映射性別(M ,F(xiàn)),Hibernate提供了AttributeConverter解決上述場(chǎng)景的轉(zhuǎn)換問(wèn)題

public enum Gender { MALE( ’M’ ), FEMALE( ’F’ ); private final char code; Gender(char code) { this.code = code; } public static Gender fromCode(char code) { if ( code == ’M’ || code == ’m’ ) { return MALE; } if ( code == ’F’ || code == ’f’ ) { return FEMALE; } throw new UnsupportedOperationException( 'The code ' + code + ' is not supported!' ); } public char getCode() { return code; }}

User實(shí)體類定義如下,重點(diǎn)在 @Convert(converter = GenderConverter.class)注釋

@Entity@Data@ToString@Table(name = 'user')public class User { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Integer id; private String name; @Convert(converter = GenderConverter.class) private Gender gender;}

定義一個(gè)GenderConverter的類,需要實(shí)現(xiàn)AttributeConverter接口,實(shí)現(xiàn)convertToDatabaseColumn和convertToEntityAttribute,作用是分別封裝從實(shí)體類映射至數(shù)據(jù)庫(kù)字段數(shù)值的邏輯和從數(shù)據(jù)庫(kù)字段數(shù)值映射到代碼實(shí)體類中的枚舉類值。

public class GenderConverter implements AttributeConverter<Gender,Character> { @Override public Character convertToDatabaseColumn(Gender gender) { if ( gender == null ) { return null; } return gender.getCode(); } @Override public Gender convertToEntityAttribute(Character value) { if ( value == null ) { return null; } return Gender.fromCode( value ); }}測(cè)試

@SpringBootTest@Slf4jpublic class AttributeConverterTest { @Resource private UserRepository userRepository; @Test void should_user__when__give_user() { //given User user1 = new User(null,'Janny', Gender.FEMALE); User user2 = new User(null,'Tom', Gender.MALE); //when User actUser1 = userRepository.save(user1); User actUser2 = userRepository.save(user2); //then Assertions.assertNotNull(actUser1); Assertions.assertNotNull(actUser2); }}

Springboot JPA 枚舉Enum類型存入到數(shù)據(jù)庫(kù)的操作

例外Hibernate也提供其他的方法,如使用@Enumerated注解,詳情可閱讀這篇文檔

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 久久在线影院 | 久久大胆视频 | 中文字幕曰韩一区二区不卡 | 国产精品福利午夜h视频 | 国产黄色片在线观看 | 荡公乱妇蒂芙尼中文字幕 | 亚洲爆爽| 嫩模大尺度人体福利视频 | 国厂自拍| 一级视频在线播放 | 欧美国产伦久久久久 | 国产女厕偷窥系列在线视频 | 欧美日韩亚洲在线观看 | 中文字幕国产欧美 | 欧美日韩亚洲一区二区三区在线观看 | 日韩在线视频不卡一区二区三区 | 久草视频免费在线观看 | 成人国产精品一级毛片视频 | 日本卡一卡2卡3卡4精品卡无人区 | 欧美三级黄色大片 | 欧美一区二区精品系列在线观看 | 亚洲国产一级毛片 | 精品在线观看视频 | 成人午夜网站 | 韩国三级 mp4 | 亚洲黄色性视频 | 欧美一级大黄特黄毛片视频 | 美女啪啪网站又黄又免费 | 亚洲在线影院 | 欧美成人性色大片在线观看 | 欧美成人毛片在线视频 | 在线观看精品国产 | 日韩欧美一区二区三区免费看 | 成人a毛片 | 亚洲综合国产一区二区三区 | 久草网首页| 在线播放精品一区二区啪视频 | 另类女最新视频 | 免费一级肉体全黄毛片高清 | 色屁屁一区二区三区视频国产 | 精品亚洲一区二区三区 |