>  기사  >  데이터 베이스  >  JDBC에서 \'0000-00-00 00:00:00\' 타임스탬프를 처리하는 방법은 무엇입니까?

JDBC에서 \'0000-00-00 00:00:00\' 타임스탬프를 처리하는 방법은 무엇입니까?

DDD
DDD원래의
2024-11-01 09:25:30431검색

How to Handle '0000-00-00 00:00:00' Timestamps in JDBC?

JDBC 오류 처리: '0000-00-00 00:00:00' 타임스탬프 표현 처리

데이터베이스를 다룰 때 흔히 발생하는 일 빈 날짜가 삽입되어 '0000-00-00 00:00:00'과 같은 비현실적인 값이 자동 할당되는 시나리오가 발생합니다. MySQL을 사용하고 Java의 java.sql.Timestamp를 사용하여 이러한 값이 포함된 데이터를 검색하려고 하면 "...'0000-00-00 00:00:00'을 Java로 표현할 수 없습니다."라는 오류가 발생할 수 있습니다. .sql.Timestamp."

데이터베이스 테이블 구조를 수정하지 않고 이 문제를 해결하려면 다음 구성 매개변수가 포함된 JDBC URL을 활용할 수 있습니다.

zeroDateTimeBehavior=convertToNull

이 매개변수를 데이터 소스 구성에서 '0000-00-00 00:00:00' 타임스탬프 값이 java.sql.Timestamp로 표시될 때 null 값으로 변환되도록 지정할 수 있습니다. 이를 통해 잘못된 타임스탬프 표현과 관련된 오류 없이 ResultSet을 검색할 수 있습니다.

다음은 zeroDateTimeBehavior 매개변수를 포함하는 JDBC URL의 예입니다.

jdbc:mysql://yourserver:3306/yourdatabase?zeroDateTimeBehavior=convertToNull

이 구성을 활용하면 데이터베이스에 '0000-00-00 00:00:00'으로 저장된 타임스탬프를 원활하게 처리할 수 있으므로 중단 없이 데이터를 검색하고 처리할 수 있습니다.

위 내용은 JDBC에서 \'0000-00-00 00:00:00\' 타임스탬프를 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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