Closes #1309
@ -139,7 +139,12 @@ public class DefaultDataAccessStrategy implements DataAccessStrategy {
*/
@Override
public <S> boolean update(S instance, Class<S> domainType) {
return operations.update(sql(domainType).getUpdate(), sqlParametersFactory.forUpdate(instance, domainType)) != 0;
SqlIdentifierParameterSource parameterSource = sqlParametersFactory.forUpdate(instance, domainType);
if (parameterSource.size() <= 1) {
return true; // returning true, because conceptually the one row was correctly updated
}
return operations.update(sql(domainType).getUpdate(), parameterSource) != 0;
/*
@ -81,4 +81,8 @@ class SqlIdentifierParameterSource extends AbstractSqlParameterSource {
addValue(identifier, others.getValue(name), others.getSqlType(name));
int size() {
return namesToValues.size();
@ -983,6 +983,16 @@ class JdbcAggregateTemplateIntegrationTests {
assertThat(template.save(entity).id).isNotNull();
@Test // GH-1309
void updateIdOnlyAggregate() {
WithIdOnly entity = new WithIdOnly();
template.save(entity);
@Test // GH-1232
@EnabledOnFeature(IS_HSQL)
void beforeSaveCallbackEffectsAreVisibleForInsert() {