MySQL 준비된 문: "MySQLSyntaxErrorException" 오류 극복
MySQL용 JDBC에서 준비된 문을 활용할 때는 올바른 구문과 용법. 개발자가 직면하는 일반적인 오류 중 하나는 "MySQLSyntaxErrorException"입니다. 이 오류의 특정 사례와 해당 해결 방법을 살펴보겠습니다.
문제:
MySQL 커넥터를 사용하는 Java 기반 애플리케이션에서 실행 시 "MySQLSyntaxErrorException"이 발생합니다. 준비된 진술. 코드는 데이터 검색을 위해 다음 문을 사용합니다.
<code class="java">PreparedStatement stmt = con.prepareStatement(selectSQL); stmt.setInt(1, ad_id); rs = stmt.executeQuery(selectSQL);</code>
실행 시 오류가 발생합니다.
오류 메시지:
com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '?' at line 1
해결책:
오류는 준비된 명령문을 실행하는 구문에 있습니다. 특히 다음 줄은 올바르지 않습니다.
<code class="java">rs = stmt.executeQuery(selectSQL);</code>
준비된 문을 실행하기 위한 올바른 구문은 다음과 같습니다.
<code class="java">rs = stmt.executeQuery();</code>
executeQuery 메서드에서 selectSQL 인수를 생략하면 문이 실행됩니다.
설명:
Prepared 문에서는 문 준비 중에 SQL 쿼리가 전달되고, 매개 변수는 다음을 사용하여 별도로 설정됩니다. setX 메소드(예: setInt) ExecuteQuery 메소드는 인수 없이 호출되어야 하는 결과 세트를 가져오는 데 사용됩니다. 원본 코드에는 ExecuteQuery 메서드 호출에 SQL 쿼리 문자열이 잘못 포함되어 구문 오류가 발생했습니다.
위 내용은 MySQL JDBC의 준비된 명령문에서 \'MySQLSyntaxErrorException\'이 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!