[SPRING] h2 데이터베이스 연결
주의 🚨
H2 데이터베이스 서버를 먼저 실행해두자.
데이터베이스 연결
ConnectionConst
src/main/java/hello/jdbc/connection/ConnectionConst.java
public abstract class ConnectionConst {
public static final String URL = "jdbc:h2:tcp://localhost/~/test";
public static final String USERNAME = "sa";
public static final String PASSWORD = "";
}
데이터베이스에 접속하는데 필요한 기본 정보를 편리하게 사용할 수 있도록 상수로 만들었다.
이제 JDBC를 사용해서 실제 데이터베이스에 연결하는 코드를 작성해보자.
DBConnectionUtil
src/main/java/hello/jdbc/connection/DBConnectionUtil.java
import java.sql.Connection;
import static hello.jdbc.connection.ConnectionConst.*;
@Slf4j
public class DBConnectionUtil {
public static Connection getConnection(){
try {
Connection connection = DriverManager.getConnection(URL, USERNAME, PASSWORD);
log.info("get connection={}, class={}", connection, connection.getClass());
return connection;
} catch (SQLException e) {
throw new IllegalStateException(e);
}
}
}
데이터베이스에 연결하려면 JDBC가 제공하는 DriverManager.getConnection(..)
를 사용하면 된다.
이렇게 하면 라이브러리에 있는 데이터베이스 드라이버를 찾아서 해당 드라이버가 제공하는 커넥션을 반환해준다.
여기서는 H2 데이터베이스 드라이버가 작동해서 실제 데이터베이스와 커넥션을 맺고 그 결과를 반환해준다.
간단한 학습용 테스트 코드를 만들어서 실행해보자.
테스트
DBConnectionUtilTest
src/test/java/hello/jdbc/connection/DBConnectionUtilTest.java
@Slf4j
class DBConnectionUtilTest {
@Test
void connection(){
Connection connection = DBConnectionUtil.getConnection();
assertThat(connection).isNotNull();
}
}
주의 🚨
실행전에 H2 데이터베이스 서버를 실행해두어야 한다.
실행 결과
DBConnectionUtil - get connection=conn0: url=jdbc:h2:tcp://localhost/~/test user=SA, class=class org.h2.jdbc.JdbcConnection
실행 결과를 보면 class=class org.h2.jdbc.JdbcConnection
부분을 확인할 수 있다.
이것이 바로 H2 데이터베이스 드라이버가 제공하는 H2 전용 커넥션이다. 물론 이 커넥션은 JDBC 표준 커넥션 인터페이스인 java.sql.Connection
인터페이스를 구현하고 있다.
💛 개인 공부 기록용 블로그입니다. 👻