Postgresql에서 "열이 존재하지 않습니다" 오류 해결
PostgreSQL과 Java 간에 연결을 설정했음에도 불구하고 시도할 때 오류가 발생합니다. "'mac' 열이 존재하지 않습니다."라는 메시지와 함께 삭제 작업을 수행합니다. 테이블에 MAC 열이 있음에도 불구하고 이 문제는 Postgresql 엔터티 이름의 대/소문자 구분으로 인해 발생합니다.
이 문제를 해결하려면 열 이름에 대문자가 포함된 경우 큰따옴표(" ")로 묶으십시오. . 귀하의 경우 쿼리를 다음과 같이 수정하세요.
String stm = "DELETE FROM hostdetails WHERE \"MAC\" = 'kzhdf'";
추가로 보안을 강화하고 SQL 주입 취약점을 방지하려면 준비된 문을 활용하고 매개변수를 통해 값을 설정하세요.
con = DriverManager.getConnection(url, user, password); String stm = "DELETE FROM hostdetails WHERE \"MAC\" = ?"; pst = con.prepareStatement(stm); pst.setString(1, "kzhdf"); pst.executeUpdate();
이 접근 방식은 다음과 같습니다. 열 이름과 값이 정확히 일치하는지 확인하여 "열이 존재하지 않습니다." 오류를 방지하고 코드 보안을 강화합니다.
위 내용은 Java에서 PostgreSQL의 '열이 존재하지 않습니다' 오류를 수정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!