PreparedStatement 실행 시 "SQL 구문에 오류가 있습니다."
PreparedStatement를 사용하여 쿼리를 실행할 때 사용자는 "?" 근처에서 MySQLSyntaxErrorException이 발생할 수 있습니다. 이 오류는 SQL 쿼리의 구문 오류를 나타냅니다.
이 특정 문제에서 코드는 '?`×位符를 사용하여 쿼리 매개변수를 대체하려고 시도하지만, preparedStatement가 이러한 자리 표시자를 올바르게 대체하지 않습니다.
문제는 ExecuteQuery() 메서드 호출에 있습니다. 코드는 s.executeQuery() 대신 s.executeQuery(query)를 호출하여 준비된 쿼리를 원래 쿼리로 덮어씁니다. 준비된 쿼리를 실행하려면 인수가 없는 ExecutionQuery() 메서드를 사용해야 합니다.
PreparedStatement s = conn.prepareStatement(query); s.setInt(1, intValue); s.setString(2, strValue); rs = s.executeQuery(); // Correct
또한 코드에서 닫히지 않은 연결, 문 및 결과 집합으로 인해 리소스가 누출될 수 있습니다. 리소스 고갈을 방지하려면 finally 블록에서 리소스를 닫아야 합니다.
try { ... } finally { if (rs != null) rs.close(); if (s != null) s.close(); if (conn != null) conn.close(); }
위 내용은 Java의 ReadyStatement에서 ''?' 근처의 MySQL 구문 오류'가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!