Альтернатива Connection.setAutoCommit(false), поскольку она не работает для JdbcTemplate.JAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Альтернатива Connection.setAutoCommit(false), поскольку она не работает для JdbcTemplate.

Сообщение Anonymous »

Я просматриваю несколько руководств, в которых говорится, что для запуска транзакции необходимо написать
connection.setAutoCommit(false)
Но кажется, что это игнорируется JdbcTemplate, который я использую для фактической вставки записей.
Могут ли кто-нибудь поделиться кодом транзакции, который работает с JdbcTemplate, но не включает @Transactional, потому что моя цель — попытаться смоделировать @Transactional, чтобы лучше понять, что он делает.
Итак, в приведенном ниже коде я получаю соединение от jdbcTeamplate и использую его для запуска транзакции, но оно игнорируется при вставке записей с помощью jdbcTeamplate внутри репозитория.
PersonService.java
@Service
public class PersonService {

//PROPERTIES
@Autowired private PersonRepository personRepository;
@Autowired private JdbcTemplate jdbcTemplate;

//=========================================================================================================
// INSERT RECORDS
//=========================================================================================================
public void insertRecords() throws SQLException {

//GET DB CONNECTION
Connection connection = jdbcTemplate.getDataSource().getConnection();

//FIRST RECORD IS ALWAYS INSERTED (It is outside the Transaction)
Person person0 = new Person(0, "Person Outside Transaction", 100);
personRepository.save(person0);

//TRANSACTION
try { //It doesn't work with try(connection) => throws java.sql.SQLRecoverableException

//START TRANSACTION
connection.setAutoCommit(false);

//EXECUTE SQL STATEMENTS
for (int i = 1; i

Подробнее здесь: https://stackoverflow.com/questions/786 ... or-jdbctem
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»