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 중국어 웹사이트의 기타 관련 기사를 참조하세요!