> 데이터 베이스 > MySQL 튜토리얼 > `IllegalArgumentException`을 피하기 위해 Java ReadyStatements에서 setDate()를 올바르게 사용하는 방법은 무엇입니까?

`IllegalArgumentException`을 피하기 위해 Java ReadyStatements에서 setDate()를 올바르게 사용하는 방법은 무엇입니까?

DDD
풀어 주다: 2025-01-18 22:27:11
원래의
413명이 탐색했습니다.

How to Correctly Use setDate() in Java PreparedStatements to Avoid `IllegalArgumentException`?

PreparedStatement에서 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을 기본값으로 사용하여 날짜 변수가 잘못 초기화되었다는 것입니다. 이 문제를 해결하려면 날짜를 처리할 때 다음 대안을 고려하십시오.

java.sql.날짜

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>
    로그인 후 복사

java.sql.Timestamp

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿