关于mapstruct的qualifiedByName和expression的使用(解决List类型映射成String的情况)

@Mapper
public interface CarMapper {

    CarMapper INSTANCE = Mappers.getMapper(CarMapper.class);

    /**
     * 映射
     * @param car
     * @return
     */
    @Mappings({
            @Mapping(target = "buyTime", source = "buyTime", dateFormat = "yyyy-MM-dd HH:mm:ss"),
            @Mapping(target = "constant", constant = "HAHA"),
            //使用expression的方式
//            @Mapping(target = "wheels",
//                    expression = "java(com.alibaba.fastjson.JSON." +
//                            "toJSONString(car.getWheels()))")
            //使用qualifiedByName的方式
            @Mapping(target = "wheels", qualifiedByName = "listToString")
    })
    CarEntity toCarEntity(Car car);

    @Named("listToString")
    default String listToString(List<Wheel> wheels){
        return JSON.toJSONString(wheels);
    }
}

 

### MapStruct 复杂对象映射 #### 定义复杂映射场景 当面对具有多层嵌套结构的对象时,MapStruct 提供了多种方式来实现这些复杂映射。对于包含列表或其他集合类型的属性,可以通过配置`@Mappings`注解下的多个`@Mapping`子项指定源目标字段间的转换关系[^1]。 ```java import org.mapstruct.Mapper; import org.mapstruct.Mapping; import org.mapstruct.Mappings; @Mapper(componentModel = "spring") public interface ComplexObjectMapper { @Mappings({ @Mapping(target = "name", source = "source.name"), @Mapping(target = "address.city", source = "source.address.cityName"), // 嵌套属性映射 @Mapping(target = "contacts.emails", expression = "java(mapEmailList(source.getEmailAddresses()))") // 集合映射 }) TargetDTO convert(SourceEntity source); default List<String> mapEmailList(List<EmailAddress> emails){ return emails.stream().map(EmailAddress::getEmail).collect(Collectors.toList()); } } ``` #### 条件映射支持 为了应对某些特定条件下才执行的映射需求,可以在方法上应用`@Condition`或是在默认方法内部加入判断逻辑[^2]: ```java default boolean isEligibleForConversion(TargetType target, SourceType source) { return null != source && !StringUtils.isEmpty(source.getValueToCheck()); } @ConditionalMapping(conditionExpression = "java(isEligibleForConversion(target, source))") void conditionalConvert(@MappingTarget TargetType target, SourceType source); ``` #### 自定义映射函数 针对无法直接通过简单表达式完的任务,则可利用接口内的默认方法来自定义映射行为[^4]: ```java default String customTransform(String input){ // 实现具体的业务逻辑... return transformedValue; } @Mapping(target="customField", expression="java(customTransform(source.customData))") CustomDTO transform(CustomSource src); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值