首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ModelMapper不忽略空值

ModelMapper不忽略空值
EN

Stack Overflow用户
提问于 2019-05-29 19:21:40
回答 3查看 3.7K关注 0票数 1

我想对我的一个实体进行部分更新,但是如果一个属性为null,那么要更新的实体也会将该值设置为null。我希望如果源文件中的属性为空,则保留源文件中的属性。

我试过了,但没有成功:

代码语言:javascript
复制
    @Bean
    public ModelMapper modelMapper() {
        ModelMapper modelMapper = new ModelMapper();
        modelMapper.getConfiguration().setPropertyCondition(Conditions.isNotNull());
        modelMapper.createTypeMap(String.class, Date.class);
        modelMapper.addConverter(new StringToDate());
        modelMapper.addConverter(new DateToString());
        return modelMapper;
    }

然后我像这样更新我的对象:

代码语言:javascript
复制
    @Override
    public void editUser(final User user) {
        UserDocument userDocument = this.usersRepository.findByIdAndActivo(user.getId(), true)
                .orElseThrow(UserNotFoundException::new);

        userDocument = this.modelMapper.map(user, UserDocument.class);
        this.usersRepository.save(userDocument);
    }

user对象有1个属性设置为null,而对象userDocument有一个值,当我将它保存在数据库中时,这个值就消失了(因为它已经转换为null)。

会出什么问题呢?

谢谢。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2019-05-29 20:19:57

好的,这个配置并不是我想的那样。

我已经解决了这个问题,通过将更新的对象与旧的对象合并,如下所示:

代码语言:javascript
复制
    @Override
    public void editUser(final User user) {
        UserDocument userDocument = this.usersRepository.findByIdAndActivo(user.getId(), true)
                .orElseThrow(UserNotFoundException::new);

        this.modelMapper.map(user, userDocument);
        this.usersRepository.save(userDocument);
    }
票数 4
EN

Stack Overflow用户

发布于 2020-06-25 01:49:22

您可以通过以下方式求解:

代码语言:javascript
复制
@Configuration
public class ModelMapperConfig {

    @Bean
    public ModelMapper modelMapper() {
        ModelMapper modelMapper = new ModelMapper();
        modelMapper.getConfiguration().setSkipNullEnabled(true);

        return modelMapper;
    }
}
票数 2
EN

Stack Overflow用户

发布于 2019-05-29 19:49:32

Mybatis框架?您还没有设置选择性保存--选择性

<insert id="insertSelective" parameterType="com.zjl.domain"> insert into table_name <trim prefix="(" suffix=")" suffixOverrides=","> <if test="id != null"> id, </if> <if test="createDate != null"> create_date, </if> <if test="modifiedDate != null"> modified_date, </if> </trim> <trim prefix="values (" suffix=")" suffixOverrides=","> <if test="id != null"> #{id,jdbcType=BIGINT}, </if> <if test="createDate != null"> #{createDate,jdbcType=TIMESTAMP}, </if> <if test="modifiedDate != null"> #{modifiedDate,jdbcType=TIMESTAMP}, </if> </trim> </insert>

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56359427

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档