인프런 커뮤니티 질문&답변

YN L님의 프로필 이미지
YN L

작성한 질문수

스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술

순수 JDBC

h2 대신 오라클 사용시 member.setID(rs.getLong1));에서 NumberFormatException 오류

작성

·

387

0

개인 공부를 위해 일부러 h2 DB 대신 오라클 DB를 사용하여 구동하려고 하고있습니다.
build.gradle에서 오라클.ojdbc8 적어 주었고 application.properties에서 spring.datasource.driver-class-name=oracle.jdbc.driver.OracleDriver 로 오라클 db와 연결하는데 성공시켰습니다.
해서 member save를 해보려는데 서버가 정상적으로 열리고 회원등록 페이지로 이동해서 제출 버튼을 누르니 DB에 저장 자체는은 정상적으로 되었습니다.
 
하지만 mainpage로 redirect:/ 되지도 않고 NumberFormatException이 떠서 위치를 보니 if(rs.next()) 아래 member.setId(rs.getLong(1)); 가 원인이였습니다.
 
 
 
어차피 insert 부분이라 member.setId를 할 필요가 있을까 싶어 주석처리한 결과 에러 뜨는 것 없이 잘 작동되었고 mainpage로 redirect:/ 도 잘 되네요.
 
찾아보니 문자형을 숫자형으로 변환하다 발생한 오류라는데 bigint가 아니라서 발생한 오류인 건가요??
 
테이블 생성 시 사용한 쿼리문은 다음과 같습니다.
create table member2 ( id NUMBER(19), name varchar(255), primary key (id) ); CREATE SEQUENCE mem_seq START WITH 1 INCREMENT BY 1 MAXVALUE 100 CYCLE NOCACHE;

=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
여기에 질문 내용을 남겨주세요.

답변 1

0

안녕하세요. YN L님, 공식 서포터즈 OMG입니다.

네, 말씀하신 상황을 보니 예상하신대로 id 타입관련 문제일 수 있겠네요.

테이블에서 id타입을 바꾸거나 자바에서 id 타입을 int로 바꿔서 확인해보시면 될 것 같습니다.

감사합니다.

YN L님의 프로필 이미지
YN L

작성한 질문수

질문하기