Как повторно использовать то же соединение с JdbcTemplate Spring?

Многие объяснения уже присутствуют, чтобы объяснить, как это происходит и как это исправить, но вы также должны следовать рекомендациям, чтобы избежать NullPointerException вообще.

См. также: A хороший список лучших практик

Я бы добавил, очень важно, хорошо использовать модификатор final. Использование "окончательной" модификатор, когда это применимо в Java

Сводка:

  1. Используйте модификатор final для обеспечения хорошей инициализации.
  2. Избегайте возврата null в методы, например, при возврате пустых коллекций.
  3. Использовать аннотации @NotNull и @Nullable
  4. Быстрое завершение работы и использование утверждений, чтобы избежать распространения нулевых объектов через все приложение, когда они не должен быть пустым.
  5. Сначала используйте значения с известным объектом: if("knownObject".equals(unknownObject)
  6. Предпочитают valueOf() поверх toString ().
  7. Используйте null safe StringUtils StringUtils.isEmpty(null).

25
задан User1 10 February 2011 в 18:34
поделиться

2 ответа

Spring предоставляет специальный источник данных, который позволяет вам делать это: SingleConnectionDataSource

Изменение кода на это должно помочь:

SingleConnectionDataSource dataSource = new SingleConnectionDataSource();
....
// The rest stays as is

Для использования в многопоточных приложениях вы можете повторно ввести код, заимствовав новое соединение из пула и обернув его вокруг части кода, интенсивно использующей базу данных:

// ... this code may be invoked in multiple threads simultaneously ...

try(Connection conn = dao.getDataSource().getConnection()) {
    JdbcTemplate db = new JdbcTemplate(new SingleConnectionDataSource(conn, true));

    // ... database-intensive code goes here ... 
    // ... this code also is safe to run simultaneously in multiple threads ...
    // ... provided you are not creating new threads inside here
}
26
ответ дан Alex R 10 February 2011 в 18:34
поделиться

Вам нужно, чтобы вызовы были объединены в одну транзакцию. Обычно вы делаете это с аннотацией Spring AOP + @Transactional в приложении. Вы также можете сделать это программно с помощью PlatformTranactionManager, TransactionTemplate и обернуть код для выполнения в TransactionCallback. См. документацию по транзакции .

5
ответ дан reevesy 10 February 2011 в 18:34
поделиться
Другие вопросы по тегам:

Похожие вопросы: