При использовании этой функции в качестве параметра передаётся не конкретное значение, а класс-реализация NamedParamHandler
.
Рассмотрим пример использования:
В этом случае невозможно заранее обработать и сгенерировать конкретное значение в серверном коде, так как логика обновления зависит от требований, возникающих у сотрудников в разное время.
NamedParamHandler
Этот тип поддерживает только именованный способ работы (paramName
соответствует имени параметра в SQL), и класс-реализация может генерировать нужное значение на основе этого имени.
public interface NamedParamHandler {
/**
* При именованном способе можно генерировать значения по своему усмотрению, например случайные числа.
* Возвращаемое значение должно быть простым типом, поддерживаемым JDBC для передачи параметров, и не может быть списком, массивом или другим сложным объектом.
*
* @param paramName имя параметра
* @return значение
*/
Object getValue(String paramName);
}
Ниже представлен пример реализации генератора случайных чисел JdbcRandomNamedParamHandler
, который генерирует значения в диапазоне от 10 до 30. Более подробно можно ознакомиться с исходным кодом класса JdbcRandomNamedParamHandler
:
String sql = "insert into UserInfo(userInfoId,loginName,password,userAge) values(:userInfoId,:loginName,:password,:random_z10_z30)";
for (int i = 0; i < 10; i++) {
jdbcDao.nativeExecutor()
.namedParameter()
.command(sql)
.parameter("userInfoId", 99L + i)
.parameter("loginName", "newName")
.parameter("password", "123456")
.parameter("random_z10_z30", new JdbcRandomNamedParamHandler())
.insert();
}
Вы можете оставить комментарий после Вход в систему
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.
Опубликовать ( 0 )