使用Java 8 Lambda表達(dá)式將實(shí)體映射到DTO的操作
當(dāng)我們需要將DTO轉(zhuǎn)換為實(shí)體(Hibernate實(shí)體等)并向后轉(zhuǎn)換時(shí),我們都會(huì)面臨混亂的開銷代碼。
在我的示例中,我將用Java 8演示代碼如何變得越來(lái)越短。
讓我們創(chuàng)建目標(biāo)DTO:
public class ActiveUserListDTO { public ActiveUserListDTO() { } public ActiveUserListDTO(UserEntity userEntity) { this.username = userEntity.getUsername(); ... } }
使用Spring數(shù)據(jù)JPA API檢索所有實(shí)體的簡(jiǎn)單查找方法:
userRepository.findAll(); Problem: Find.All() method signature (like many others) returns java.lang.Iterable<T> java.lang.Iterable<T> findAll(java.lang.Iterable<ID> iterable)
我們不能使用java.lang.Iterable(*在集合上運(yùn)行的Streams來(lái)制作Stream。每個(gè)Collection都是Iterable,但并不是每個(gè)Iterable都是必需的Collection)。
那么,如何獲取Stream對(duì)象以獲得Java8 Lambda的Power?
讓我們使用StreamSupport對(duì)象將Iterable轉(zhuǎn)換為Stream:
Stream<UserEntity> userEntityStream = StreamSupport.stream(userRepository.findAll().spliterator(), false);
大。 現(xiàn)在,我們掌握了Stream,這是Java 8 Labmda的關(guān)鍵!
剩下的就是地圖和收集:
List<ActiveUserList> activeUserListDTOs =
userEntities.stream().map(ActiveUserList::new).collect(Collectors.toList());
我正在使用Java 8 Method Reference,因此將每個(gè)實(shí)體初始化(和映射)到dto中。
因此,讓我們對(duì)所有內(nèi)容進(jìn)行簡(jiǎn)短介紹:
List<ActiveUserList> activeUserListDTOs=StreamSupport.stream(userRepository.findAll().spliterator(), false).map(ActiveUserList::new).collect(Collectors.toList());
那很整齊??!
補(bǔ)充知識(shí):java8中使用Lambda表達(dá)式將list中實(shí)體類的兩個(gè)字段轉(zhuǎn)Map
代碼:
List<Entity> list = new ArrayList<>();
Map<Integer, String> map = list.stream().collect(Collectors.toMap(Entity::getId, Entity::getType));
常用的lambda表達(dá)式:
** * List -> Map * 需要注意的是: * toMap 如果集合對(duì)象有重復(fù)的key,會(huì)報(bào)錯(cuò)Duplicate key .... * apple1,apple12的id都為1。 * 可以用 (k1,k2)->k1 來(lái)設(shè)置,如果有重復(fù)的key,則保留key1,舍棄key2 */ Map<Integer, Apple> appleMap = appleList.stream().collect(Collectors.toMap(Apple::getId, a -> a,(k1,k2)->k1)); 安照某一字段去重 list = list.stream().filter(distinctByKey(p -> ((ModCreditColumn) p).getFieldCode())).collect(Collectors.toList()); List<Double> unitNetValue = listIncreaseDto.stream().map(IncreaseDto :: getUnitNetValue).collect(Collectors.toList()); //求和 對(duì)象List BigDecimal allFullMarketPrice = entityList.stream().filter(value -> value.getFullMarketPrice()!= null).map(SceneAnalysisRespVo::getFullMarketPrice).reduce(BigDecimal.ZERO, BigDecimal::add); List<BigDecimal> naturalDayList; BigDecimal total = naturalDayList.stream().reduce(BigDecimal.ZERO, BigDecimal::add); 分組函數(shù) Map<String, List<SceneAnalysisRespVo>> groupMap = total.getGroupList().stream().collect(Collectors.groupingBy(SceneAnalysisRespVo::getVmName)); //DV01之和 BigDecimal allDV01 = values.stream().filter(sceneAnalysisRespVo -> sceneAnalysisRespVo.getDv() != null).map(SceneAnalysisRespVo::getDv).reduce(BigDecimal.ZERO, BigDecimal::add);
以上這篇使用Java 8 Lambda表達(dá)式將實(shí)體映射到DTO的操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
java處理數(shù)據(jù)庫(kù)不支持的emoji表情符問題解決
這篇文章主要介紹了java處理數(shù)據(jù)庫(kù)不支持的emoji表情符問題解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09云計(jì)算實(shí)驗(yàn):Java?MapReduce編程
這篇文章主要介紹了云計(jì)算實(shí)驗(yàn):Java?MapReduce編程,?居于Java圍繞MapReduce編程展開詳細(xì)內(nèi)容,文章助大家掌握MapReduce編程,理解MapReduce原理,需要的朋友可以參考一下2021-12-12java 中Spark中將對(duì)象序列化存儲(chǔ)到hdfs
這篇文章主要介紹了java 中Spark中將對(duì)象序列化存儲(chǔ)到hdfs的相關(guān)資料,需要的朋友可以參考下2017-06-06Java中this和super的區(qū)別及this能否調(diào)用到父類使用
這篇文章主要介紹了Java中this和super的區(qū)別及this能否調(diào)用到父類使用,this和super都是Java中常見的關(guān)鍵字,下文關(guān)于兩者區(qū)別介紹,需要的小伙伴可以參考一下2022-05-05Java可重入鎖的實(shí)現(xiàn)原理與應(yīng)用場(chǎng)景
今天小編就為大家分享一篇關(guān)于Java可重入鎖的實(shí)現(xiàn)原理與應(yīng)用場(chǎng)景,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-01-01老生常談Java虛擬機(jī)垃圾回收機(jī)制(必看篇)
下面小編就為大家?guī)?lái)一篇老生常談Java虛擬機(jī)垃圾回收機(jī)制(必看篇)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2017-08-08Java?spring?通過注解方式創(chuàng)建對(duì)象的示例詳解
這篇文章主要介紹了java?spring?通過注解方式創(chuàng)建對(duì)象,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-02-02