테이블 별칭이 있는 JDBC ResultSet 열
"SELECT * from table1 a, table2 b where (WHATEVER)"와 같은 쿼리를 실행할 때, "resultSet.getString("a.columnName")"을 사용하여 데이터에 액세스하거나 "resultSet.getString("b.columnName")"이 실패합니다.
JDBC API는 이 시나리오를 명시적으로 처리하지 않으므로 공급업체에 따라 다릅니다. 그러나 다음 방법으로 이 문제를 해결할 수 있습니다.
옵션 1: 열 이름 바꾸기
다음과 같이 별칭을 사용하여 쿼리에서 열 이름을 다르게 지정합니다.
SELECT a.columnName as columnNameA, b.columnName as columnNameB, ... from table1 a, table2 b where (WHATEVER)
그런 다음 Java에서 이러한 별칭을 참조하세요. 코드:
resultSet.getString("columnNameA"); resultSet.getString("columnNameB");
옵션 2: 열 위치
결과 집합의 위치별로 열 참조:
resultSet.getString(1); resultSet.getString(2);
JDBC에 유의하세요. 첫 번째 열은 1부터 시작하는 1 기반 인덱싱을 사용합니다.
안전과 유지 관리가 용이하므로 옵션 1(열 이름 바꾸기)을 권장합니다. 쿼리의 열 순서가 변경되면 잘못된 열에 액세스하면 코드가 자동으로 중단됩니다. 반면에 열 이름을 변경하면 "해당 열 없음" 예외가 발생하여 문제를 경고합니다.
위 내용은 테이블 별칭을 사용하여 JDBC ResultSet 열에 액세스하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!