Не удается поймать исключение DataIntegrityViolationException - PullRequest
0 голосов
/ 22 сентября 2018

Я использую Spring Boot 2 с spring-boot-starter-data-jpa с базовой MariaDB.

У меня есть таблица с уникальным ключом "username".Я хочу поймать DataIntegrityViolationException, если это ограничение нарушено, но кажется, что Spring регистрирует DataIntegrityViolationException и не сбрасывает после регистрации (моя лучшая догадка).Вместо этого выдается MySQLIntegrityConstraintViolationException.

Я бы хотел поймать DataIntegrityViolationException в UserService.createUser(..).

Вот несколько фрагментов кода:

@Repository
@Transactional(propagation = Propagation.MANDATORY)
public class UserRepository {

    @PersistenceContext
    private EntityManager entityManager;

    public void save(User user) {
        entityManager.persist(user);
    }
}

@Service
@Transactional(value = Transactional.TxType.REQUIRED)
public class UserService {

@Autowired
private UserRepository userRepository;

private void createUser(User user){
    userRepository.save(user);
}

Stacktrace:

2018-09-22 14:20:33.163  WARN 10700 --- [nio-8080-exec-1] o.h.engine.jdbc.spi.SqlExceptionHelper   : SQL Error: 1062, SQLState: 23000
2018-09-22 14:20:33.163 ERROR 10700 --- [nio-8080-exec-1] o.h.engine.jdbc.spi.SqlExceptionHelper   : Duplicate entry 'kkflf' for key 'user_username_uindex'
2018-09-22 14:20:33.163 ERROR 10700 --- [nio-8080-exec-1] o.h.i.ExceptionMapperStandardImpl        : HHH000346: Error during managed flush [org.hibernate.exception.ConstraintViolationException: could not execute statement]
2018-09-22 14:20:33.177 ERROR 10700 --- [nio-8080-exec-1] o.a.c.c.C.[.[.[/].[dispatcherServlet]    : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is org.springframework.dao.DataIntegrityViolationException: could not execute statement; SQL [n/a]; constraint [user_username_uindex]; nested exception is org.hibernate.exception.ConstraintViolationException: could not execute statement] with root cause

com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Duplicate entry 'kkflf' for key 'user_username_uindex'
...

1 Ответ

0 голосов
/ 22 сентября 2018

Я решил проблему.

Исключение не возникает, пока транзакция не завершится, что имеет смысл.

Мне удалось перехватить исключение вне области транзакции в классе контроллера.

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