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

Mary-Kate Olsen
풀어 주다: 2024-11-19 11:15:02
원래의
487명이 탐색했습니다.

Why Does My PreparedStatement in Java Throw a MySQL Syntax Error?

PreparedStatement 구문 오류

Java에서 ReadyStatements는 매개변수화된 SQL 쿼리에 향상된 안전성과 성능을 제공합니다. 그러나PreparedStatements에서 구문 오류가 발생하면 실망스러울 수 있습니다.

이 특별한 경우 원본 코드는 다음 SQL을 실행하려고 할 때 MySQL 구문 오류를 발생시킵니다.

SELECT `value` FROM `sampling_numbers` WHERE `value` < (?)
로그인 후 복사

오류의 근원 원인은 의도된 ReadyStatement 메소드 대신에 State 메소드를 호출하는 stmt.executeQuery(sql);의 잘못된 사용에 있습니다. 이 문제를 해결하려면 다음과 같이 코드를 수정하면 됩니다.

return this.stmt.executeQuery();
로그인 후 복사

이 수정을 통해 preparedStatement의 매개변수가 올바르게 바인딩되고 SQL 쿼리가 올바르게 실행됩니다.

위 내용은 Java의 ReadyStatement에서 MySQL 구문 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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