JDBC에서 Date 클래스를 다루는 것은 상당한 고충이 될 수 있습니다. 데이터베이스는 날짜, 시간, 타임스탬프를 포함한 다양한 날짜/시간 필드 형식을 제공하는 경우가 많습니다. JDBC는 각 형식에 해당하는 Java 클래스를 제공하며, 모두 java.util.Date에서 상속됩니다.
JDBC 드라이버는 이러한 유형을 잘못 처리하여 버그를 일으키는 경우가 많습니다. 예를 들어 sql.Date는 시간대별로 다를 수 있지만 sql.Time은 데이터에 해당 정보가 없음에도 불구하고 현재 연도, 월, 일을 포함할 수 있습니다.
결국 선택은 액세스되는 필드의 SQL 유형에 따라 달라집니다. preparedStatement는 #setDate(), #setTime() 및 #setTimestamp()의 세 가지 유형 모두에 대한 설정자를 제공합니다.
그러나 ps.setObject(fieldIndex, utilDateObject)를 사용한다는 점에 유의하는 것이 중요합니다. 일반 util.Date를 사용하면 데이터베이스에서 데이터를 검색할 때 문제가 발생할 수 있습니다.
이상적으로 날짜와 시간은 밀리초 또는 나노초를 나타내는 일반 long 형식으로 저장해야 합니다. 이는 객체 간에 쉽게 변환되거나 SQL 쿼리에서 직접 사용될 수 있습니다. 이 접근 방식은 JDBC/Java Date API의 복잡성과 잠재적인 함정을 방지합니다.
위 내용은 Java 날짜와 SQL 날짜: JDBC에서 어느 것을 사용해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!