PreparedStatement::setDate 및 ResultSet을 사용하는 기존 방식 ::getDate는 레거시 java.sql.Date 유형에 대해 작동합니다. 그러나 이러한 번거로운 이전 날짜-시간 클래스는 사용하지 않는 것이 좋습니다. 대신 최신 java.time 유형을 사용하세요.
JDBC를 통해 java.time 객체를 교환하는 경로는 두 가지가 있습니다.
JDBC 드라이버가 이를 준수하는 경우 JDBC 4.2 사양 이상에서는 java.time 객체를 직접 처리할 수 있습니다. 호환 드라이버는 java.time 유형을 인식하고 이를 처리하기 위해 setObject/getObject 메소드를 추가했습니다.
데이터베이스에 데이터를 보내려면 java.time 객체를 preparedStatement::setObject에 전달하기만 하면 됩니다. 전달된 인수의 Java 유형은 드라이버에 의해 감지되어 적절한 SQL 유형으로 변환됩니다. Java LocalDate는 SQL DATE 유형으로 변환됩니다.
데이터베이스에서 데이터를 검색하려면 ResultSet::getObject를 호출하세요. 결과 Object 객체를 캐스팅하는 대신 수신할 것으로 예상되는 데이터 유형의 클래스인 추가 인수를 전달할 수 있습니다. 예상 클래스를 지정하면 IDE와 컴파일러에서 유형 안전성을 확인하고 검증할 수 있습니다.
JDBC 드라이버가 아직 JDBC 4.2를 준수하지 않는 경우 또는 나중에 java.time 객체를 해당 java.sql 유형으로 간단히 변환하거나 그 반대로 변환해야 합니다. 기존 클래스에 추가된 새로운 변환 방법을 살펴보세요.
다음은 LocalDate 값을 H2 데이터베이스에 삽입하고 선택하는 방법을 보여주는 전체 작업 예제 앱입니다.
import java.sql.*; import java.time.LocalDate; import java.time.ZoneId; import java.util.UUID; public class App { public static void main ( String[] args ) { App app = new App ( ); app.doIt ( ); } private void doIt ( ) { try { Class.forName ( "org.h2.Driver" ); } catch ( ClassNotFoundException e ) { e.printStackTrace ( ); } try ( Connection conn = DriverManager.getConnection ( "jdbc:h2:mem:trash_me_db_" ) ; Statement stmt = conn.createStatement ( ) ; ) { String tableName = "test_"; String sql = "CREATE TABLE " + tableName + " (\n" + " id_ UUID DEFAULT random_uuid() PRIMARY KEY ,\n" + " date_ DATE NOT NULL\n" + ");"; stmt.execute ( sql ); // Insert row. sql = "INSERT INTO test_ ( date_ ) " + "VALUES (?) ;"; try ( PreparedStatement preparedStatement = conn.prepareStatement ( sql ) ; ) { LocalDate today = LocalDate.now ( ZoneId.of ( "America/Montreal" ) ); preparedStatement.setObject ( 1 , today.minusDays ( 1 ) ); // Yesterday. preparedStatement.executeUpdate ( ); preparedStatement.setObject ( 1, today ); // Today. preparedStatement.executeUpdate ( ); preparedStatement.setObject ( 1, today.plusDays ( 1 ) ); // Tomorrow. preparedStatement.executeUpdate ( ); } // Query all. sql = "SELECT * FROM test_"; try ( ResultSet rs = stmt.executeQuery ( sql ) ; ) { while ( rs.next ( ) ) { UUID id = rs.getObject ( "id_" , UUID.class ); // Pass the class to be type-safe. LocalDate localDate = rs.getObject ( "date_", LocalDate.class ); // Pass class for type-safety. System.out.println ( "id_: " + id + " | date_: " + localDate ); } } } catch ( SQLException e ) { e.printStackTrace ( ); } } }
위 내용은 데이터베이스 상호 작용을 위해 JDBC와 함께 java.time 유형을 효과적으로 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!