> 데이터 베이스 > MySQL 튜토리얼 > `s.executeQuery(query)`가 ''?' 근처' MySQLSyntaxErrorException을 발생시키는 이유는 무엇입니까?

`s.executeQuery(query)`가 ''?' 근처' MySQLSyntaxErrorException을 발생시키는 이유는 무엇입니까?

Patricia Arquette
풀어 주다: 2024-12-23 08:44:10
원래의
770명이 탐색했습니다.

Why Does `s.executeQuery(query)` Cause a MySQLSyntaxErrorException

"?" 근처의 MySQLSyntaxErrorException: ReadyStatements로 구문 오류 해결

Java에서 preparedStatements를 실행하면 구문 오류가 발생할 수 있습니다. 그 중 하나는 다음과 같습니다. "'?' 근처" 예외가 두렵습니다. 원인과 해결 방법을 이해하기 위해 문제를 자세히 살펴보겠습니다.

문제 설명

PreparedStatement를 실행하려고 시도하면 구문을 나타내는 오류 코드 1064와 함께 MySQLSyntaxErrorException이 발생합니다. 오류. MySQL 쿼리 브라우저를 사용하여 쿼리 값을 대체하면 문제가 코드 내에 있음을 알 수 있습니다.

관련 코드

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); // Error
로그인 후 복사

예외

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
로그인 후 복사

해결 방법

이 오류의 근본 원인은 MySQL에서 처리되지 않은 "?" 오류가 발생했습니다. SQL 쿼리에서. 이 문제를 해결하려면 다음 단계를 따르세요.

  1. 재정의된 준비된 쿼리: 이 코드는 준비된 준비된 쿼리의 의도된 동작을 재정의합니다. ResultSet rs = s.executeQuery(query); 줄 은(는) 올바르지 않습니다.
  2. 올바른 실행: 대신 인수가 없는 preparedStatement#executeQuery() 메서드를 사용하여 준비된 쿼리를 올바르게 실행하세요.
ResultSet rs = s.executeQuery();
로그인 후 복사

추가 고려사항

  • 리소스 누수: 코드가 연결, 명령문 및 결과 세트를 적절하게 닫지 않습니다. 리소스 누출을 방지하려면 try-with-resources 블록을 구현하세요.

위 내용은 `s.executeQuery(query)`가 ''?' 근처' MySQLSyntaxErrorException을 발생시키는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿