>  기사  >  데이터 베이스  >  MySQL JDBC의 준비된 명령문에서 \"MySQLSyntaxErrorException\"이 발생하는 이유는 무엇입니까?

MySQL JDBC의 준비된 명령문에서 \"MySQLSyntaxErrorException\"이 발생하는 이유는 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-10-31 00:48:29357검색

Why Does My Prepared Statement in MySQL JDBC Throw a

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

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