Java의 preparedStatement에서 '?' 근처에서 MySQL 구문 오류가 발생하는 이유는 무엇입니까?
PreparedStatement 질문 관련 MySQL 구문 오류
Java에서 ReadyStatement를 사용하여 쿼리를 실행하려고 하면 "?" 근처에 구문 오류를 나타내는 오류가 발생합니다. 예외는 다음과 같습니다.
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
코드 조각
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); // Fail!
문제 해결
MySQL이 "?"를 인식하지 못하기 때문에 오류가 발생합니다. SQL 쿼리에서 자리 표시자로 사용됩니다. 이는 다음 호출로 인해 발생합니다.
rs = s.executeQuery(query); // Fail!
인수 없이 preparedStatement#executeQuery를 사용하는 대신 원래 쿼리 문자열이 전달되어 준비된 문을 재정의합니다.
문제를 해결하려면 , preparedStatement의 excuteQuery 메소드는 인수 없이 호출되어야 합니다:
rs = s.executeQuery(); // OK!
Resource 누출
원래 문제와는 관련이 없지만 코드에서 리소스가 누출됩니다. 이를 방지하려면 JDBC 관용어를 사용하여 리소스를 닫아야 합니다.
try { // Acquire resources here } catch (Exception e) { // Handle exception } finally { // Close resources here }
위 내용은 Java의 preparedStatement에서 '?' 근처에서 MySQL 구문 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Java의 클래스 로딩에는 부트 스트랩, 확장 및 응용 프로그램 클래스 로더가있는 계층 적 시스템을 사용하여 클래스로드, 링크 및 초기화 클래스가 포함됩니다. 학부모 위임 모델은 핵심 클래스가 먼저로드되어 사용자 정의 클래스 LOA에 영향을 미치도록합니다.

이 기사는 카페인 및 구아바 캐시를 사용하여 자바에서 다단계 캐싱을 구현하여 응용 프로그램 성능을 향상시키는 것에 대해 설명합니다. 구성 및 퇴거 정책 관리 Best Pra와 함께 설정, 통합 및 성능 이점을 다룹니다.

이 기사는 캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA를 사용하는 것에 대해 설명합니다. 잠재적 인 함정을 강조하면서 성능을 최적화하기위한 설정, 엔티티 매핑 및 모범 사례를 다룹니다. [159 문자]

이 기사에서는 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 및 Gradle을 사용하여 접근 방식과 최적화 전략을 비교합니다.

이 기사에서는 Maven 및 Gradle과 같은 도구를 사용하여 적절한 버전 및 종속성 관리로 사용자 정의 Java 라이브러리 (JAR Files)를 작성하고 사용하는 것에 대해 설명합니다.
