>  기사  >  데이터 베이스  >  UNIX 타임스탬프를 날짜로 변환할 때 SimpleDateFormat.parse가 지정된 것과 다르게 출력되는 이유는 무엇입니까?

UNIX 타임스탬프를 날짜로 변환할 때 SimpleDateFormat.parse가 지정된 것과 다르게 출력되는 이유는 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-30 03:06:28447검색

Why does SimpleDateFormat.parse output differently than specified when converting UNIX timestamps to dates?

SimpleDateFormatter.parse가 지정된 것과 다르게 출력됩니다

SimpleDateFormat을 사용하여 UNIX 타임스탬프를 날짜로 변환할 때 지정된 형식과 출력.

주어진 예에서 목표는 UNIX 타임스탬프("a1527069600")를 "dd/MM/yyyy hh:mm:ss a" 형식의 날짜로 변환하는 것입니다. 그러나 SimpleDateFormatter.format과 SimpleDateFormatter.parse를 차례로 사용하면 다른 출력이 생성됩니다.

불일치의 원인

SimpleDateFormatter.parse가 정확한 문자열을 예상하기 때문에 불일치가 발생합니다. 인스턴스화 중에 지정된 형식("dd/MM/yyyy hh:mm:ss a"). 이 경우 SimpleDateFormatter.format은 예상 입력 형식과 다른 형식으로 날짜를 출력하므로 구문 분석 작업이 실패하게 됩니다.

해결 방법

이 문제를 방지하려면 , MySQL 데이터베이스에 날짜 문자열을 전달하지 않는 것이 좋습니다. 대신 날짜 객체를 사용하세요. 최신 Java 날짜 및 시간 API인 java.time은 날짜 처리를 더 쉽게 해주는 LocalDateTime과 같은 클래스를 제공합니다.

예:

<code class="java">String ep = "a1527069600";
long epoch = Long.parseLong(ep.substring(1));
Instant inst = Instant.ofEpochSecond(epoch);
LocalDateTime ldt = inst.atZone(ZoneId.of("Asia/Calcutta")).toLocalDateTime();

System.out.println(ldt.toString()); // Output: 2018-05-23T15:30

PreparedStatement ps = myDatabaseConnection.prepareStatement(
        "insert into my_table (my_date_time) values (?)");
ps.setObject(1, ldt);</code>

이 코드는 UNIX를 변환합니다. MySQL 데이터베이스에 직접 삽입할 수 있는 LocalDateTime의 타임스탬프.

결론:

java.time을 활용하고 문자열 대신 날짜 객체를 MySQL에 전달함으로써, 형식 문제를 제거하고 날짜 변환의 정확성을 보장할 수 있습니다.

위 내용은 UNIX 타임스탬프를 날짜로 변환할 때 SimpleDateFormat.parse가 지정된 것과 다르게 출력되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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