Package org.mybatis.dynamic.sql.update
Interface UpdateDSLCompleter
- All Superinterfaces:
Function<UpdateDSL<UpdateModel>,Buildable<UpdateModel>>
- Functional Interface:
- This is a functional interface and can therefore be used as the assignment target for a lambda expression or method reference.
@FunctionalInterface
public interface UpdateDSLCompleter
extends Function<UpdateDSL<UpdateModel>,Buildable<UpdateModel>>
Represents a function that can be used to create a general update method. When using this function,
you can create a method that does not require a user to call the build() and render() methods - making
client code look a bit cleaner.
This function is intended to be used in conjunction in the utility method like
MyBatis3Utils.update(ToIntFunction, SqlTable, UpdateDSLCompleter)
For example, you can create mapper interface methods like this:
@UpdateProvider(type=SqlProviderAdapter.class, method="update")
int update(UpdateStatementProvider updateStatement);
default int update(UpdateDSLCompleter completer) {
return MyBatis3Utils.update(this::update, person, completer);
}
And then call the simplified default method like this:
int rows = mapper.update(c ->
c.set(firstName).equalTo("Fred")
.where(id, isEqualTo(100))
);
You can implement an "update all" simply by omitting a where clause:
int rows = mapper.update(c ->
c.set(firstName).equalTo("Fred")
);
You could also implement a helper method that would set fields based on values of a record. For example, the following method would set all fields of a row based on whether the values are null:
static UpdateDSL<UpdateModel> updateSelectiveColumns(PersonRecord record,
UpdateDSL<UpdateModel> dsl) {
return dsl.set(id).equalToWhenPresent(record::getId)
.set(firstName).equalToWhenPresent(record::getFirstName)
.set(lastName).equalToWhenPresent(record::getLastName)
.set(birthDate).equalToWhenPresent(record::getBirthDate)
.set(employed).equalToWhenPresent(record::getEmployed)
.set(occupation).equalToWhenPresent(record::getOccupation);
}
The helper method could be used like this:
rows = mapper.update(c ->
PersonMapper.updateSelectiveColumns(record, c)
.where(id, isLessThan(100)));
In this way, you could mimic the function of the old style "updateByExampleSelective" methods from MyBatis Generator.
- Author:
- Jeff Butler
-
Method Summary