"?" 근처의 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 쿼리에서. 이 문제를 해결하려면 다음 단계를 따르세요.
ResultSet rs = s.executeQuery();
추가 고려사항
위 내용은 `s.executeQuery(query)`가 ''?' 근처' MySQLSyntaxErrorException을 발생시키는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!