>데이터 베이스 >MySQL 튜토리얼 >열이 존재하는데도 내 Java JDBC 코드에 PostgreSQL에서 '열이 존재하지 않습니다' 오류가 발생하는 이유는 무엇입니까?

열이 존재하는데도 내 Java JDBC 코드에 PostgreSQL에서 '열이 존재하지 않습니다' 오류가 발생하는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-20 20:04:11460검색

Why Does My Java JDBC Code Get a

Java JDBC에서 PostgreSQL의 "열이 존재하지 않습니다" 오류 문제 해결

문제:

PostgreSQL과 상호작용하기 위해 JDBC를 사용하는 Java 애플리케이션은 열이 데이터베이스에 분명히 존재하는 경우에도 "열이 존재하지 않습니다." 예외를 발생시킬 수 있습니다. 이는 SQL 쿼리의 정확한 테이블 및 열 이름에도 불구하고 종종 발생합니다.

근본 원인:

PostgreSQL은 대소문자를 구분합니다. JDBC는 기본적으로 쿼리를 보내기 전에 열 이름을 소문자로 변환합니다. 열 이름에 대문자가 포함된 경우 이 변환으로 인해 불일치 및 오류가 발생합니다.

해결책:

해결 방법은 간단합니다. SQL 쿼리 내에서 열 이름을 큰따옴표로 묶으면 됩니다. 이렇게 하면 JDBC의 자동 소문자 변환이 방지되어 데이터베이스가 올바른 대소문자를 수신하게 됩니다.

예:

countries 스키마 내의 network 테이블을 쿼리하여 Continent 열을 검색하려고 한다고 가정해 보겠습니다. 문제가 있는 쿼리는 다음과 같습니다.

<code class="language-sql">SELECT Continent
FROM network.countries
...</code>

큰따옴표를 사용한 수정된 쿼리는 다음과 같습니다.

<code class="language-sql">SELECT "Continent"
FROM network.countries
...</code>

이 수정을 통해 "Continent"가 데이터베이스에 정의된 대로 정확하게 PostgreSQL에 전달되어 "열이 존재하지 않습니다" 오류가 해결됩니다.

모범 사례:

대소문자 구분 문제를 방지하려면 JDBC를 통해 PostgreSQL과 상호 작용할 때 SQL 쿼리의 열 이름 주위에 항상 큰따옴표를 사용하세요. 이 간단한 예방 조치로 잠재적인 두통을 예방할 수 있습니다.

위 내용은 열이 존재하는데도 내 Java JDBC 코드에 PostgreSQL에서 '열이 존재하지 않습니다' 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.