>Java >java지도 시간 >Java의 ReadyStatement에서 ''?' 근처의 MySQL 구문 오류'가 발생하는 이유는 무엇입니까?

Java의 ReadyStatement에서 ''?' 근처의 MySQL 구문 오류'가 발생하는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-11 15:43:11341검색

Why Am I Getting a

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

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