山水有相逢& 2019-09-28 12:31 采纳率: 100%
浏览 2326
已采纳

lambda表达式,可以取出其中几个元素么

有这么个实体类


实体类一: entityOne

private Integer  parameterOne

private String   parameterTwo

private String   parameterThree

private String   parameterFour

实体类一: entityDto


private String   parameterTwo

private String   parameterFour

现在我 select * from entity 查询,

返回一个 List < entityOne > entityOnelist 的结果 ,一般我想要用Lambda表达式
来取出parameterTwo,可以这么写

 List list= entityOnelist.stream().map(e->e.getparameterTwo).collect(Collectors.toList())

但我现在想取出parameterTwo和parameterFour 改怎么用Lambda表达式写, 然后用DTO去接收?
还是说我得重新在写一个sql语句?


望大神解答!!

-------------------谢谢

  • 写回答

1条回答 默认 最新

  • threenewbee 2019-09-28 12:37
    关注

    因为lambda表达式里面的参数是强类型的,比如你的e,这里只能是 entityOne,所以如果你要 entityTwo,要么必须
    entityTwo和entityOne抽象出一个接口来,都包含parameterTwo字段,或者用Object类型作为参数,表达式内用反射(但是效率比较差)获取字段。


    class entityDto

    {
    private String parameterTwo;

    private String parameterFour;
    public entityDto(String a, String b)
    {
    parameterTwo=a; parameterFour=b;
    }
    }

    List list= entityOnelist.stream().map(e->new entityDto(e.parameterTwo, e. parameterFour)).collect(Collectors.toList())

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?