Я поместил @Transactional в методе, но он фиксирует транзакцию перед откатом - PullRequest
3 голосов
/ 29 февраля 2020

Как добиться управления транзакциями в Spring

Мои методы, как показано ниже

@Transactional(rollbackFor = RuntimeException.class, propagation = Propagation.REQUIRED)
@Override
public InwardDTO saveEntity(InwardDTO entity) throws Exception {
    try {
        costCalculation(entity);
        InwardDTO dto = super.saveEntity(entity);
        addStock(dto.getDetails(), dto.getId());
        return dto;
    } catch (Exception ex) {
        throw ex;
    }
}

private void addStock(Set<InwardDetailsDTO> argDetailsDTOSet, Long argInwardId) throws RuntimeException {
    String SUBMODULE = getModuleNameForLog() + " [addStock()] ";

    if (1 == 1) {
        throw new RuntimeException("Test Case");
    }
}

Журналы похожи,

2020-02-29 15:01:14.210 TRACE 14504 --- [nio-8080-exec-2] o.s.t.i.TransactionInterceptor           : Getting transaction for [org.springframework.data.jpa.repository.support.SimpleJpaRepository.save]
Hibernate: insert into tbl_inward_chemical (date, invoice_number, is_deleted, party_id, po_id, pre_inward_id_id, remark, slip, total_amount, total_weight) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
Hibernate: insert into tbl_inward_details_chemical (inward_id, is_deleted, is_pass, party_moisture_id, party_ph_id, party_price, party_purity_id, party_solubility_id, party_weight, product_name_id, received_moisture_id, received_ph_id, received_price, received_purity_id, received_solubility_id, received_weight, total_price) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
Hibernate: insert into tbl_inward_details_chemical (inward_id, is_deleted, is_pass, party_moisture_id, party_ph_id, party_price, party_purity_id, party_solubility_id, party_weight, product_name_id, received_moisture_id, received_ph_id, received_price, received_purity_id, received_solubility_id, received_weight, total_price) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
2020-02-29 15:01:14.216 TRACE 14504 --- [nio-8080-exec-2] o.s.t.i.TransactionInterceptor           : Completing transaction for [org.springframework.data.jpa.repository.support.SimpleJpaRepository.save]
2020-02-29 15:01:14.216 TRACE 14504 --- [nio-8080-exec-2] o.s.t.i.TransactionInterceptor           : Completing transaction for [com.alignedorg.chemical.inward.service.InwardService.saveEntity] after exception: java.lang.RuntimeException: Test Case
2020-02-29 15:01:14.216 TRACE 14504 --- [nio-8080-exec-2] o.s.t.i.RuleBasedTransactionAttribute    : Applying rules to determine whether transaction should rollback on java.lang.RuntimeException: Test Case
2020-02-29 15:01:14.216 TRACE 14504 --- [nio-8080-exec-2] o.s.t.i.RuleBasedTransactionAttribute    : Winning rollback rule is: RollbackRuleAttribute with pattern [java.lang.RuntimeException]
2020-02-29 15:01:14.222 ERROR 14504 --- [nio-8080-exec-2] c.a.core.utillity.log.ApplicationLogger  :  [ Inward Controller ]  [SAVE] Test Case

java.lang.RuntimeException: Test Case

В этой транзакции всегда фиксируется до откат метода addStock ... В журналах показывается, что транзакция является откатом, но запись сохраняется в БД ...

Ответы [ 2 ]

1 голос
/ 29 февраля 2020

Список обязательных компонентов транзакции Spring:

1.JdbcTemplate

@Bean(name = "jdbcTemplate")
public JdbcTemplate creatJdbcTemplate(@Qualifier("dataSource") DataSource dataSource) {
    return new JdbcTemplate(dataSource);
}

2.DataSource

@Bean(name = "dataSource")
public DataSource creatDataSource() {
    DriverManagerDataSource ds = new DriverManagerDataSource();
    ds.setDriverClassName(driverClassName);
    ds.setUrl(url);
    ds.setUsername(username);
    ds.setPassword(password);
    return ds;
}

3.TransactionManager

@Bean(name = "transactionManager")
public PlatformTransactionManager creatTransactionManager(DataSource  dataSource) {
    return new DataSourceTransactionManager(dataSource);
}

4. @EnableTransactionManagement над одним @Configuration Class для активации TxManager

5.Используйте экземпляр JdbcTemplate (@Autowired) в DaoImplements для выполнения sql с query() || update() метод

0 голосов
/ 29 февраля 2020

В случае, если механизм хранения таблиц - MyISAM: этот механизм не поддерживает транзакции. Правильный вариант должен быть InnoDB.

Если вы используете автоматическое c создание таблиц из Hibernate: я бы порекомендовал написать свои собственные миграции и использовать такой инструмент, как Flyway . , Это немного больше работы, но вы будете иметь полный контроль над тем, как выглядят ваши таблицы.

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