日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Spring boot JPA實現分頁和枚舉轉換代碼示例

瀏覽:142日期:2023-08-10 17:36:20

1.實現分頁

方法一:使用Pageable

使用Pageable作為入參傳入Repository,返回值用Page<T>接收

UserRepository

package com.kinglead.demo.dao; ​ import com.kinglead.demo.entity.User; import org.springframework.data.jpa.repository.JpaRepository; ​ public interface UserRepository extends JpaRepository<User, Long> { }

UserServiceImpl

package com.kinglead.demo.service.impl; ​ import com.kinglead.demo.dao.UserRepository; import com.kinglead.demo.entity.User; import com.kinglead.demo.service.UserService; import org.springframework.data.domain.Page; import org.springframework.data.domain.Pageable; import org.springframework.stereotype.Service; ​ import javax.annotation.Resource; ​ @Service public class UserServiceImpl implements UserService { ​ @Resource private UserRepository userRepository; ​ /** * 查詢用戶列表 */ @Override public Page<User> queryAll(Pageable pageable) { return userRepository.findAll(pageable); } ​ }

UserService

package com.kinglead.demo.service; ​ import com.kinglead.demo.entity.User; import org.springframework.data.domain.Page; import org.springframework.data.domain.Pageable; ​ import java.util.List; import java.util.Map; ​ public interface UserService { /** * 查詢用戶列表 */ Page<User> queryAll(Pageable pageable); }

Controller

/** * 查詢用戶列表 */ @GetMapping('/userList') public Page<User> queryAll(){ //注意,前端頁面的頁面是從1開始,而JPA是從0開始 Pageable pageable = PageRequest.of(0,5); //查詢用戶列表 return userService.queryAll(pageable); }

方法二:以元模型概念為基礎的Criteria 查詢方法

UserRepository額外繼承JpaSpecificationExecutor<>

package com.kinglead.demo.dao; ​ import com.kinglead.demo.entity.User; import org.springframework.data.jpa.repository.JpaRepository; import org.springframework.data.jpa.repository.JpaSpecificationExecutor; ​ public interface UserRepository extends JpaRepository<User, Long>, JpaSpecificationExecutor<User> { }

UserServiceImpl

/** * 查詢用戶列表 */ @Override public Page<User> queryAll(String name,String age,Pageable pageable) { Specification<User> specification = (Specification<User>)(root, query, criteriaBuilder) ->{ List<Predicate> list = new ArrayList<>(); // 第一個name為User實體對象中的字段,第二個name為參數 Predicate p1 = criteriaBuilder.equal(root.get('name'),name); list.add(p1); //if (!age.equals(null)) { // // 此處為查詢serverName中含有age的數據 // Predicate p2 = criteriaBuilder.like(root.get('age'),'%'+age+'%' ); // list.add(p2); //} return criteriaBuilder.and(list.toArray(new Predicate[0])); }; return userRepository.findAll(specification,pageable); }

其它代碼如方法一,不用動。

2.枚舉轉換

**方法一:實體類加@Enumerated注解

package com.kinglead.demo.enums;import com.fasterxml.jackson.annotation.JsonValue;public interface BaseEnum<K> { /** * 真正與數據庫進行映射的值 * * @return */ K getCode(); /** * 顯示的信息 * * @return */ @JsonValue //jackson返回報文response的設置 String getDisplayName();}

package com.kinglead.demo.enums; ​ public enum GenderEnum implements BaseEnum<String> { ​ MALE('MALE','男'), FEMALE('FEMALE','女'); ​ ​ private final String code; private final String displayName; ​ GenderEnum(String code, String displayName) { this.code = code; this.displayName = displayName; } ​ @Override public String getCode() { return code; } ​ @Override public String getDisplayName() { return displayName; }}

package com.kinglead.demo.entity; ​ import com.kinglead.demo.enums.GenderEnum; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; ​ import javax.persistence.*; import java.io.Serializable; ​ @Data //添加getter、setter方法 @NoArgsConstructor //無參構造函數 @AllArgsConstructor //所以參數構造函數 @Entity //聲明為JPA實體 @Table(name = 't_user') //該標注與@Entity標注并列使用,用于指明數據庫的表名 public class User implements Serializable { private static final long serialVersionUID = -21070736985722463L; ​ @Id //指明主鍵 @GeneratedValue(strategy= GenerationType.AUTO) private Long id; ​ @Column(name = 'name', columnDefinition = '姓名') //指明字段 private String name; ​ @Column(name = 'age', columnDefinition = '年齡') //指明字段 private Long age; ​ @Column(name = 'email', columnDefinition = '郵箱') //指明字段 private String email; ​ @Column(name = 'gender', columnDefinition = '性別') //指明字段 @Enumerated(EnumType.STRING) private GenderEnum gender; ​ }

方法二:使用jpa2.1規范里面的屬性轉換器

將方法一中實體對象User的gender成員變量上的注解@Enumerated(EnumType.STRING)去掉

package com.kinglead.demo.config; ​ import com.kinglead.demo.enums.GenderEnum; ​ import javax.persistence.AttributeConverter; import javax.persistence.Converter; ​ @Converter(autoApply = true) public class ColorConverter implements AttributeConverter<GenderEnum,String> { ​ @Override public String convertToDatabaseColumn(GenderEnum attribute) { return attribute.getCode(); } ​ @Override public GenderEnum convertToEntityAttribute(String dbData) { return GenderEnum.valueOf(dbData); } }

上面的轉換器只是針對某一種枚舉進行轉換,如果寫成通用的轉換器呢,后續研究

源碼地址:https://github.com/kinglead2012/myblog

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲精品乱码| 免费日本视频一区| 日韩精品久久久久久| 蜜桃av一区二区在线观看| 九九综合在线| 久久高清一区| 欧美精品一区二区久久| 一区三区视频| 亚洲日韩视频| 国产精品久久久久77777丨| 日本一区二区中文字幕| 91伊人久久| 成人国产精品一区二区网站| 日韩欧美午夜| 日韩午夜精品| 69堂精品视频在线播放| 欧美成人aaa| 美女一区网站| 亚洲视频电影在线| 欧美日韩亚洲一区| 国产91在线播放精品| 高潮久久久久久久久久久久久久| 97精品国产福利一区二区三区| se01亚洲视频| 亚洲aa在线| 91一区二区三区四区| 一本色道精品久久一区二区三区| 日韩精品亚洲aⅴ在线影院| 久久精品人人| aa国产精品| 精品一区91| 丝袜国产日韩另类美女| 欧美日韩a区| 亚洲精品99| 国产传媒在线观看| 日韩av一二三| 亚洲成人va| 国产精品一区二区精品视频观看| 久久三级视频| 国产精品99久久久久久董美香| 尤物精品在线| 九九色在线视频| 久久99偷拍| 日韩av网站在线免费观看| 91精品在线观看国产| 免费在线日韩av| 日本不卡中文字幕| 狠狠干成人综合网| 日韩啪啪电影网| 国产一区丝袜| 国产精品久av福利在线观看| 亚洲大片在线| 中文字幕在线官网| 精品一区二区三区中文字幕视频 | 久久影院一区二区三区| 婷婷视频一区二区三区| 亚洲综合二区| 999在线观看精品免费不卡网站| 福利在线免费视频| 麻豆91小视频| 久久不卡日韩美女| 久久亚洲精精品中文字幕| 麻豆精品少妇| 久久不见久久见中文字幕免费 | 亚洲精品中文字幕乱码| 日韩av首页| 国内亚洲精品| 国产亚洲高清视频| 三级欧美韩日大片在线看| 丝袜国产日韩另类美女| 免费看日韩精品| 国产欧美二区| 波多视频一区| 99xxxx成人网| 亚洲+小说+欧美+激情+另类| 日本欧美韩国一区三区| 国产日韩中文在线中文字幕| 欧美一区不卡| 日韩成人a**站| 欧美国产91| 亚洲精品麻豆| 国精品产品一区| 99精品在线观看| 日韩亚洲精品在线观看| 美女视频免费精品| 亚洲激情中文在线| 国产精品高潮呻吟久久久久| 免费在线观看一区| 中文一区一区三区免费在线观| 日韩欧美一区二区三区免费看| 欧美肉体xxxx裸体137大胆| 中文字幕免费精品| 国产日韩视频在线| 日本在线高清| 日韩一区二区三区四区五区 | 免费人成网站在线观看欧美高清| 69堂免费精品视频在线播放| 久久久一本精品| 国产视频一区二区在线播放| 久久视频一区| 久久成人av| 中文字幕日韩高清在线| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 97成人在线| 欧美特黄一级大片| 国产精品久久乐| 亚洲精品系列| 一本一本久久| 99视频精品全国免费| 国产精品99精品一区二区三区∴ | 日韩午夜视频在线| 五月天久久777| 国产a亚洲精品| 国产精品久久久久av蜜臀 | 国产中文欧美日韩在线| 亚洲精品极品| 蜜桃av一区| 视频在线在亚洲| 中国女人久久久| 亚洲少妇一区| 鲁大师影院一区二区三区| 欧美/亚洲一区| 日本aⅴ精品一区二区三区| 免费久久99精品国产自在现线| 蜜臀va亚洲va欧美va天堂 | 久久av免费| 亚洲少妇诱惑| 噜噜噜躁狠狠躁狠狠精品视频| 精品一区毛片| 久久午夜视频| 综合干狼人综合首页| 日韩影院免费视频| 婷婷亚洲成人| 国产精久久久| 亚洲精品永久免费视频| 日韩av免费| 在线一区欧美| 日韩欧美三区| 国内自拍视频一区二区三区| 黑人精品一区| 狠狠久久婷婷| 一区二区电影| 国产精品www.| 久久国产欧美| 亚洲我射av| 麻豆一区二区三区| 欧美福利在线| 日本不卡一区二区三区| 国产精品久久久久久av公交车| 日韩欧美一区二区三区免费看| 激情自拍一区| 久久国产精品免费一区二区三区 | 免费国产亚洲视频| 国产日韩欧美在线播放不卡| 久久av偷拍| 亚洲深爱激情| 精品国产美女a久久9999| 亚洲午夜黄色| 国产精品久一| 久久午夜精品一区二区| 精品国产aⅴ| 日韩中文字幕区一区有砖一区 | 成人羞羞视频播放网站| 日韩精品中文字幕一区二区| 中文字幕在线视频久| 亚洲人妖在线| 国产黄大片在线观看| 综合激情在线| 亚洲手机视频| 色综合狠狠操| 久久国产三级| 视频精品一区二区| 欧洲av一区二区| 麻豆国产精品一区二区三区| 久热精品在线| 欧美日韩国产高清| 日韩欧美一区二区三区免费看| 国产日韩欧美在线播放不卡| 99香蕉国产精品偷在线观看 | 在线亚洲欧美| 香蕉久久精品| zzzwww在线看片免费| 91午夜精品| 日韩一区二区三区免费视频| 99日韩精品| 鲁大师影院一区二区三区| 久久人人97超碰国产公开结果| 91欧美国产| 成人看片网站| 新版的欧美在线视频| 国产精品一区毛片| 久久国内精品自在自线400部| 亚洲精品少妇| 亚洲+小说+欧美+激情+另类| 伊人久久亚洲| 日韩欧乱色一区二区三区在线| 日韩高清欧美激情| 91成人福利| 欧美激情一区| 手机在线电影一区|