JDBC 이해 강의에서 DB연결 에러
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)
[질문 내용]
여기에 질문 내용을 남겨주세요.
김영한 선생님 안녕하세요.
JDBC 이해에서 데이터베이스를 연결하려고 하는데 계속 에러가 납니다.
에러내용

java.lang.IllegalStateException: org.h2.jdbc.JdbcSQLNonTransientConnectionException: Database may be already in use: "C:/Users/SeoCom1/testDB.mv.db". Possible solutions: close all other connection(s); use the server mode [90020-224]
at hello.jdbc.connection.DBConnectionUtil.getConnection(DBConnectionUtil.java:17)
at hello.jdbc.connection.DBConnectionUtilTest.connection(DBConnectionUtilTest.java:10)
at java.base/java.lang.reflect.Method.invoke(Method.java:568)
at java.base/java.util.ArrayList.forEach(ArrayList.java:1511)
at java.base/java.util.ArrayList.forEach(ArrayList.java:1511)
Caused by: org.h2.jdbc.JdbcSQLNonTransientConnectionException: Database may be already in use: "C:/Users/SeoCom1/testDB.mv.db". Possible solutions: close all other connection(s); use the server mode [90020-224]
at org.h2.message.DbException.getJdbcSQLException(DbException.java:690)
at org.h2.message.DbException.getJdbcSQLException(DbException.java:489)
at org.h2.message.DbException.get(DbException.java:212)
at org.h2.mvstore.db.Store.convertMVStoreException(Store.java:165)
at org.h2.mvstore.db.Store.<init>(Store.java:142)
at org.h2.engine.Database.<init>(Database.java:326)
at org.h2.engine.Engine.openSession(Engine.java:92)
at org.h2.engine.Engine.openSession(Engine.java:222)
at org.h2.engine.Engine.createSession(Engine.java:201)
at org.h2.engine.SessionRemote.connectEmbeddedOrServer(SessionRemote.java:343)
at org.h2.jdbc.JdbcConnection.<init>(JdbcConnection.java:125)
at org.h2.Driver.connect(Driver.java:59)
at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:681)
at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:229)
at hello.jdbc.connection.DBConnectionUtil.getConnection(DBConnectionUtil.java:11)
... 4 more
Caused by: org.h2.mvstore.MVStoreException: The file is locked: C:/Users/SeoCom1/testDB.mv.db [2.2.224/7]
at org.h2.mvstore.DataUtils.newMVStoreException(DataUtils.java:996)
at org.h2.mvstore.SingleFileStore.lockFileChannel(SingleFileStore.java:143)
at org.h2.mvstore.SingleFileStore.open(SingleFileStore.java:117)
at org.h2.mvstore.SingleFileStore.open(SingleFileStore.java:81)
at org.h2.mvstore.MVStore.<init>(MVStore.java:286)
at org.h2.mvstore.MVStore$Builder.open(MVStore.java:2035)
at org.h2.mvstore.db.Store.<init>(Store.java:133)
... 14 more
Process finished with exit code -1
이렇게 코드가 나오는데
Caused by: org.h2.jdbc.JdbcSQLNonTransientConnectionException: Database may be already in use: "C:/Users/SeoCom1/testDB.mv.db". Possible solutions: close all other connection(s); use the server mode [90020-224]<-이 부분이 원인이 되는 이유인 것 같더라고요.... 구글링으로 최대한 해결해보려고 했는데 결국 어떻게 바꿔야할지 감이 잡히지 않습니다.
답변 2
1
안녕하세요. jocharlie님, 공식 서포터즈 OMG입니다.
AI 인턴의 답변을 참고하여 PC를 재부팅 한후 다시 확인해보시겠어요?
H2를 실행하기만 하고, h2 console 화면에서 접속하지 않고 확인해주세요 😀
해결이 안될 경우 댓글 남겨주세요
감사합니다.
0
h2 console화면에서 접속하지 않고 확인한다는 의미를 잘 모르겠습니다 ㅠㅠㅠ
여기까지는 잘 들어가지는데 인텔리제이 화면에서는 아까처럼 계속 에러가 납니다..ㅠㅠ
0
감사합니다!!! 이 부분은 해결이 된 것 같습니다...! 그런데 화면창을 끄고 하니
Caused by: org.h2.jdbc.JdbcSQLNonTransientConnectionException: Unsupported database file version or invalid file header in file "C:/Users/SeoCom1/testDB.mv.db" [90048-224] <- 이 에러가 뜨더라고요.... 계속 질문드려서 죄송합니다... 버전이 달라서 발생하는 오류인가요..? 이럴때는 어떻게 해결하는게 좋을까요..?
2
해당 문제는 h2 버전과 testDB파일의 생성 시 h2 버전 문제로 보이는데요,
C:/Users/SeoCom1/ 폴더로 가셔서 testDB.mv.db 파일을 삭제하시고,
https://docs.google.com/document/d/1j0jcJ9EoXMGzwAA2H0b9TOvRtpwlxI5Dtn3sRtuXQas/edit
링크의 해결방안2 를 참고하여 testDB.mv.db 파일을 재생성 해서 확인해주세요 ^^
testDB.mv.db파일을 삭제하였기 때문에 MEMBER테이블은 새로 생성해주세요 😀
0
안녕하세요, 인프런 AI 인턴입니다.
H2 데이터베이스 연결 중 ‘Database may be already in use’라는 에러 발생의 경우, 이미 데이터베이스 파일이 사용 중이거나 서버 모드 설정 문제일 수 있습니다. 유사한 문제로 질문하신 다른 수강생에 대한 강사님의 답변을 참고해 보시면 도움이 될 것 같습니다.
아래 링크의 답변 내용을 확인해 보시기 바랍니다.
- 질문 제목: Database may be already in use: null. 에러 발생 ㅠㅠ
- 강사님이 제공한 해결 방법: 컴퓨터를 재부팅 한 후 localhost:8082로 h2 데이터베이스를 띄워서 JDBC URL을 jdbc:h2:tcp://localhost/~/test 로 입력해 정상 작동하는지 확인하라는 내용입니다.
Database may be already in use: null. 에러 발생 ㅠㅠ
감사합니다.
spring initialiser 어떤걸 선택해야될지 모르겠어요
0
31
2
트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.
0
50
1
jdbc 학습하다 궁금해서 질문드려요
0
82
1
정상이체와 이체중 예외발생 차이
0
68
2
이번 강의부터가 JDBC 직접 사용 맞나요?
0
87
1
순수한 서비스 계층에 대한 의문???
0
82
2
3_4test, 4test 자동 리소스 안됨
0
58
2
데이터베이스 선택 관련 질문.
0
68
2
after 메서드 사용 유무
0
56
2
데이터베이스 접근 및 DB 락
0
54
1
@SpingBootTest, @TestConfiguration
0
56
1
Read Committed 격리 수준 사용 관련 질문
0
48
1
AopCheck Test 부분의 EnhancerBySpring 확인 법??
0
66
2
커리큘럼 관련 질문
0
76
1
서비서 계층 스프링 프레임워크 사용
0
87
1
validation(toMember)의 위치
0
83
2
데이터 계층에서 서비스 로직의 datasource를 인식하는 방법
0
165
2
member 상수 질문
0
120
2
ctrl + F6 이후로 con 인식이 안 됩니다
0
153
2
DrivenManager 와 Connection 반환에 대한 질문입니다!
0
109
1
섹션5 트랜잭션 템플릿관련 질문(이기종 DB)
0
116
1
세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?
0
99
1
트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?
0
98
1
강의 14분쯤 Exception 질문
0
114
2






