JPA 및 Hibernate를 사용하여 날짜/시간 및 타임스탬프를 UTC 시간대에 저장
데이터베이스 시스템에서 시간 데이터로 작업할 때 다음이 필수적입니다. 데이터가 저장되고 해석되는 시간대를 고려하세요. 여러 시간대에 걸쳐 일관된 날짜 및 시간 처리가 필요한 애플리케이션의 경우 UTC(협정 세계시) 시간대를 사용하면 표준 참조가 제공됩니다.
날짜/시간 값을 UTC로 저장하고 검색하도록 JPA 및 Hibernate를 구성하려면 , 현지 시간대에 관계없이 다음 단계를 수행할 수 있습니다.
JPA 엔터티 구성:
<code class="java">public class Event { @Id public int id; @Temporal(TemporalType.TIMESTAMP) @TimeZone(value = TimeZone.UTC) public java.util.Date date; }</code>
@TimeZone(값 = TimeZone.UTC)을 추가하여 ) 주석이 달린 날짜 필드에 날짜가 UTC 시간으로 해석되고 저장되어야 함을 명시적으로 지정합니다.
UTC 시간대에 대한 최대 절전 모드 구성:
Hibernate 5.2 이상:
Hibernate 5.2 이상 버전에서는 JPA 구성 파일(properties.xml)에서 hibernate.jdbc.time_zone 속성을 구성하여 Hibernate에서 사용하는 기본 시스템 시간대를 재정의할 수 있습니다. ):
<code class="xml"><property name="hibernate.jdbc.time_zone" value="UTC"/></code>
Spring Boot 애플리케이션:
Spring Boot를 사용하는 경우 application.properties 파일에서 위 속성을 설정할 수 있습니다.
<code class="properties">spring.jpa.properties.hibernate.jdbc.time_zone=UTC</code>
예:
예에 정의된 JPA 엔터티를 생각해 보세요. 날짜 필드가 2008년 2월 3일 오전 9시 30분 PST(태평양 표준시)로 설정되면 Hibernate는 값을 데이터베이스에 2008년 2월 3일 오후 5시 30분 UTC로 저장합니다. 이렇게 하면 서버 또는 현지 시간대 설정에 관계없이 UTC 시간대로 시간이 일관되게 저장되고 검색됩니다.
위 내용은 JPA 및 최대 절전 모드를 사용하여 UTC 시간대에 날짜/시간 및 타임스탬프를 저장하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!