Querydsl update子句填充skips bean null值属性

时间:2012-09-10 10:26:49

标签: java querydsl

当使用带有bean的null值属性的populate调用时,我遇到了SQLUpdateClause的问题。它只是从生成的更新SQL中跳过空值属性,而不是将相应的字段设置为NULL。

示例:

public class Bean {

    private Long id;

    private String value;

    private String value2;

    ...
}

Bean bean = ...

bean.setValue(null);
bean.setValue("value2");

SQLUpdateClause update = new SQLUpdateClause(connection, dialect, qBean);

update.populate(bean).where(qBean.id.eq(...)).execute();

将产生SQL:

update bean set value2 = 'value2' where bean.id = ...

而非期望:

update bean set value = null, value2 = 'value2' where bean.id = ...

这里有什么帮助吗? ...请

1 个答案:

答案 0 :(得分:7)

当检查querydsl源代码时,找到解决方案:

...
update.populate(bean, DefaultMapper.WITH_NULL_BINDINGS)
      .where(qBean.id.eq(...))
      .execute();
...

希望它有助于某人