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