Hibernate에서 "서버 시간대 값 'AEST'를 인식할 수 없습니다" 문제 수정
"서버 시간대 값 'AEST' 오류 '는 인식할 수 없거나 둘 이상의 시간대를 나타냅니다.'는 MySQL이 서버의 시간대와 JDBC를 인식할 수 없을 때 발생합니다. 드라이버에는 명시적인 시간대 구성이 없습니다. 이 문제를 해결하려면:
1. 연결 URL에 서버 시간대 지정:
JDBC 연결 URL에 serverTimezone 매개변수를 추가합니다. 이 매개변수는 MySQL이 사용해야 하는 시간대를 지정합니다. 이 경우 System.out.println(TimeZone.getDefault())에서 인쇄한 기본 시간대를 기준으로 시간대를 'UTC' 또는 'Australia/Melbourne'으로 설정할 수 있습니다.
jdbc:mysql://localhost:3306/database?serverTimezone=UTC
2. Hibernate 속성에서 serverTimezone 구성:
Hibernate 구성 파일(일반적으로 hibernate.cfg.xml) 내에 다음 속성을 추가합니다:
<property name="hibernate.connection.serverTimezone">UTC</property>
3. MySQL 커넥터 업그레이드:
이전 버전의 MySQL 커넥터를 사용하는 경우 시간대 관리를 완전히 지원하지 않을 수 있습니다. 호환성 향상을 위해 최신 버전(예: 8.0 이상)으로 업그레이드해 보세요.
4. 서버 시간대가 인식되는지 확인:
serverTimezone 매개변수에 지정된 시간대가 MySQL 서버에서 인식되고 지원되는지 확인하세요. MySQL에서 다음 쿼리를 실행하여 이를 확인합니다.
SELECT * FROM mysql.time_zone WHERE name = 'UTC';
5. JDBC 시간대 지원 활성화:
드물게 JDBC 드라이버가 시간대를 완벽하게 지원하려면 추가 구성이 필요할 수 있습니다. 구체적인 지침은 드라이버 설명서(예: [MySQL 커넥터 J](https://dev.mysql.com/doc/connector-j/en/connector-j-reference-configuration-properties.html))를 참조하세요.
참고: 일반적으로 단축되거나 모호한 시간대 대신 특정 시간대(예: 'UTC')를 사용하는 것이 좋습니다. (예: 'AEST') 일광 절약 시간제 전환과 같은 잠재적인 문제를 방지합니다.
위 내용은 최대 절전 모드에서 \'서버 시간대 값 \'AEST\'를 인식할 수 없습니다\' 오류를 수정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!