> 데이터 베이스 > MySQL 튜토리얼 > JDBC에서 테이블 이름에 대해 준비된 문을 사용할 수 없는 이유는 무엇입니까?

JDBC에서 테이블 이름에 대해 준비된 문을 사용할 수 없는 이유는 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2025-01-19 13:37:09
원래의
627명이 탐색했습니다.

Why Can't I Use Prepared Statements for Table Names in JDBC?

JDBC 준비 명령문에서 테이블 이름 매개변수화 처리

JDBC 준비된 명령문은 상당한 보안 및 성능 이점을 제공하지만 제한 사항이 있습니다. 그러한 제한 중 하나는 SQL 쿼리 내에서 매개변수를 테이블 이름으로 사용할 수 없다는 것입니다. 이렇게 하면 일반적으로 오류가 발생합니다.

해결책은 간단합니다. 테이블 이름에 자리 표시자를 사용하는 대신 테이블 이름을 SQL 쿼리 문자열에 직접 통합하세요. 예를 들면 다음과 같습니다.

<code class="language-java">private String query1 = "SELECT plantID, edrman, plant, vaxnode FROM " + reportDate; </code>
로그인 후 복사

수정된 이 예에서는 reportDate(실제 테이블 이름을 포함한다고 가정)가 SQL 문자열에 직접 연결됩니다. 이렇게 하면 테이블 이름을 매개변수화하려는 시도가 방지되어 준비된 명령문이 성공적으로 실행될 수 있습니다.

이 제약 조건을 기억하는 것이 중요합니다. 테이블 이름은 준비된 문 내에서 매개 변수로 처리되지 않으며 쿼리에 명시적으로 포함되어야 합니다. 그렇지 않으면 쿼리가 실패하게 됩니다.

위 내용은 JDBC에서 테이블 이름에 대해 준비된 문을 사용할 수 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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