집 >데이터 베이스 >MySQL 튜토리얼 >`IllegalArgumentException`을 피하기 위해 Java ReadyStatements에서 setDate()를 올바르게 사용하는 방법은 무엇입니까?
코드 표준화를 개선하려면 하드코딩된 SQL 변수를 준비된 명령문으로 교체하고 바인딩해야 합니다. 그러나 setDate() 메서드를 사용하는 데 문제가 있습니다.
<code class="language-java">String vDateMDYSQL = vDateMDY; java.sql.Date date = new java.sql.Date(0000-00-00); ... prs.setDate(2, date.valueOf(vDateMDYSQL));</code>
SQL문 실행시 다음과 같은 오류가 발생했습니다.
<code>java.lang.IllegalArgumentException at java.sql.Date.valueOf(Date.java:138)</code>
문제는 0000-00-00을 기본값으로 사용하여 날짜 변수가 잘못 초기화되었다는 것입니다. 이 문제를 해결하려면 날짜를 처리할 때 다음 대안을 고려하십시오.
DATE 열 유형이 있는 테이블의 경우:
문자열 사용:
<code class="language-java"> ps.setDate(2, java.sql.Date.valueOf("2013-09-04"));</code>
java.util.Date 사용:
<code class="language-java"> ps.setDate(2, new java.sql.Date(endDate.getTime()));</code>
현재 날짜 확인:
<code class="language-java"> ps.setDate(2, new java.sql.Date(System.currentTimeMillis()));</code>
TIMESTAMP 또는 DATETIME 열 유형이 있는 테이블의 경우:
문자열 사용:
<code class="language-java"> ps.setTimestamp(2, java.sql.Timestamp.valueOf("2013-09-04 13:30:00"));</code>
java.util.Date 사용:
<code class="language-java"> ps.setTimestamp(2, new java.sql.Timestamp(endDate.getTime()));</code>
현재 타임스탬프 가져오기:
<code class="language-java"> ps.setTimestamp(2, new java.sql.Timestamp(System.currentTimeMillis()));</code>
위의 방법 중 하나를 사용하여 준비된 명세서에 날짜를 올바르게 설정하면 발생한 오류를 피할 수 있습니다.
위 내용은 `IllegalArgumentException`을 피하기 위해 Java ReadyStatements에서 setDate()를 올바르게 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!