"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > UNIX 타임스탬프를 날짜로 변환할 때 SimpleDateFormat.parse가 지정된 것과 다르게 출력되는 이유는 무엇입니까?

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

2024-11-09에 게시됨
검색:869

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과 같은 클래스를 제공합니다.

예:

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);

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

결론:

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

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3