반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 | 29 |
30 | 31 |
Tags
- thymeleaf
- 생성자 주입
- 스프링
- 스프링 빈
- jdbc
- 스프링 부트 기본
- assertThrows
- springboot
- Javascript
- Effective Java
- kafka
- db
- JPA
- sqld
- mybatis
- 필드 주입
- assertThat
- 싱글톤
- @Configuration
- DIP
- SQL
- 스프링 프레임워크
- 스프링 부트
- 스프링 컨테이너
- 스프링 부트 입문
- resultMap
- DI
- 스프링부트
- java
- spring
Archives
- Today
- Total
선 조치 후 분석
[Error] JDBC-12040:Statement canceled 본문
728x90
반응형
SMALL
### Error updating database. Cause: java.sql.SQLException: JDBC-12040:Statement canceled.
StatementTimeout
Statement 하나가 얼마나 오래 수행되어도 괜찮은지에 대한 한계 값이다. JDBC API인 Statement에 타임아웃 값을 설정하며, 이 값을 바탕으로 JDBC 드라이버가 StatementTimeout을 처리한다.
JDBC API인 java.sq.Statement.setQueryTimeout() 메서드로 설정한다.
필자가 진행하는 프로젝트에서는 value='10'으로 지정되어 있었다.
쿼리는 테스트해봤지만 잘 돌아갔다. 다만, xml에 기입하여 기능을 구현하니까 계속 에러가 발생했다.
그래서 필자가 작성한 쿼리가 느린 탓인지 TimeOut이 자꾸 걸렸다...
처음엔 단순히 쿼리가 느려서인건가? 단순히 Performance 문제라고 생각을 했다.
하지만, 구글링을 하다가 더 비슷한 내용을 다루고 있는 내용을 찾아서 원인을 알게되었다.
// 에러 발생 쿼리
INSERT INTO XXTable
(A)
VALUES ((SELECT NVL(MAX(증가컬럼) + 1, 0) FROM XXTable))
* 증가 칼럼이 null이 아니면 +1씩 시켜서 그 값을 Insert 하려고 하였다. 하지만, 의도대로 돌아가지 않았다.
원인 : VALUES 인자로 스칼라 형태의 결과 값만 올 수 있습니다. (위의 쿼리는 테이블 형태의 결과를 줍니다.)
*출처 : https://ooz.co.kr/80
// 정상 작동 쿼리
INSERT INTO XXTable
(A)
SELECT ISNULL(MAX(증가컬럼) + 1, 0) FROM XXTable
이렇게하니까 문제를 해결했다..
신기..
728x90
반응형
LIST
'ETC > Error' 카테고리의 다른 글
[ERROR] Java 오류 - Syntax error on token "class", @ expected (0) | 2022.02.09 |
---|---|
[Error] Workspace UTF-8 설정 (0) | 2022.01.04 |
[JDBC-5074] Given string does not represent a number in proper format. (0) | 2021.12.28 |
[Error] nested exception is org.apache.ibatis.exceptions.PersistenceException / IllegalArgumentException (0) | 2021.12.13 |
[Java Error] NoSuchElementException? (0) | 2021.11.17 |