>데이터 베이스 >MySQL 튜토리얼 >Java를 MySQL 데이터베이스에 연결할 때 시간대를 올바르게 처리하려면 어떻게 해야 합니까?

Java를 MySQL 데이터베이스에 연결할 때 시간대를 올바르게 처리하려면 어떻게 해야 합니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-03 09:41:40251검색

How Can I Correctly Handle Timezones When Connecting Java to a MySQL Database?

Java 데이터베이스 연결에서 MySQL 시간대 변경

MySQL은 "GMT 8" 시간대로 작동하는 반면 Tomcat은 "GMT"를 사용합니다. datetime을 데이터베이스에 저장하면 값이 올바른 것처럼 보일 수 있지만 검색하면 "GMT" 값이 나타납니다. 또한 데이터베이스에서 검색된 값은 "GMT"로 변환됩니다. 이는 데이터베이스가 이를 "GMT 8"로 간주함을 의미합니다.

해결책

useTimezone 매개변수는 오래된 해결 방법입니다. 최신 솔루션의 경우 useLegacyDatetimeCode=false를 설정하고 최신 mysql JDBC 커넥터로 업그레이드하세요. 연결 URL 예시:

jdbc:mysql://localhost/mydb?useLegacyDatetimeCode=false

타임스탬프 처리

useLegacyDatetimeCode가 false로 설정된 경우 newSetTimestampInternal() 메서드가 호출됩니다. 제공된 Calendar가 null인 경우 날짜 개체는 데이터베이스의 시간대에 따라 형식이 지정됩니다.

this.tsdf = new SimpleDateFormat("''yyyy-MM-dd HH:mm:ss", Locale.US);
this.tsdf.setTimeZone(this.connection.getServerTimezoneTZ());
timestampString = this.tsdf.format(x);

날짜를 검색하려면 Calendar 없이 getTimestamp(int)를 사용하세요. 다시 말하지만, 데이터베이스 시간대는 날짜를 구성하는 데 사용됩니다.

웹 서버 시간대 무관성

이제 웹 서버의 시간대는 형식 지정과 관련이 없습니다. useLegacyDatetimecode가 true로 유지되면 웹 서버의 시간대가 사용되어 혼란을 야기합니다.

MySQL 시간대 모호성

예를 들어 EST로 설정하면 MySQL이 서버 시간대 모호성에 대해 불평할 수 있습니다. 이 문제를 해결하려면 연결 URL에 정확한 EST 시간대를 지정하세요.

jdbc:mysql://localhost/mydb?useLegacyDatetimeCode=false&serverTimezone=America/New_York

이는 MySQL에서 모호성 문제가 발생하는 경우에만 필요합니다.

위 내용은 Java를 MySQL 데이터베이스에 연결할 때 시간대를 올바르게 처리하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.