Java에서 ReadyStatement를 사용하여 쿼리를 실행하려고 하면 "?" 근처에 구문 오류를 나타내는 오류가 발생합니다. 예외는 다음과 같습니다.
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 '? or MemberName = ?' at line 1
String query = "select MemberID, MemberName from members where MemberID = ? or MemberName = ?"; Connection conn = DriverManager.getConnection(DATABASE_URL, USERNAME, PASSWORD); PreparedStatement s = conn.prepareStatement(query); s.setInt(1, 2); s.setString(2, "zen"); ResultSet rs = s.executeQuery(query); // Fail!
MySQL이 "?"를 인식하지 못하기 때문에 오류가 발생합니다. SQL 쿼리에서 자리 표시자로 사용됩니다. 이는 다음 호출로 인해 발생합니다.
rs = s.executeQuery(query); // Fail!
인수 없이 preparedStatement#executeQuery를 사용하는 대신 원래 쿼리 문자열이 전달되어 준비된 문을 재정의합니다.
문제를 해결하려면 , preparedStatement의 excuteQuery 메소드는 인수 없이 호출되어야 합니다:
rs = s.executeQuery(); // OK!
원래 문제와는 관련이 없지만 코드에서 리소스가 누출됩니다. 이를 방지하려면 JDBC 관용어를 사용하여 리소스를 닫아야 합니다.
try { // Acquire resources here } catch (Exception e) { // Handle exception } finally { // Close resources here }
위 내용은 Java의 preparedStatement에서 '?' 근처에서 MySQL 구문 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!