>데이터 베이스 >MySQL 튜토리얼 >IN(목록)을 사용할 때 내 PostgreSQL DELETE 쿼리가 '열이 존재하지 않습니다'라는 메시지와 함께 실패하는 이유는 무엇입니까?

IN(목록)을 사용할 때 내 PostgreSQL DELETE 쿼리가 '열이 존재하지 않습니다'라는 메시지와 함께 실패하는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-17 02:59:25259검색

Why Does My PostgreSQL DELETE Query Fail with

Postgres: WHERE IN(목록)이 있는 쿼리 오류 "열이 존재하지 않습니다"

PostgreSQL에서 쿼리

DELETE FROM user_job_titles WHERE id IN (
"c836d018-1d12-4507-a268-a4d80d6d3f54",
"d0961a90-7d31-4c4c-9c1b-671115e3d833",
"62dda420-6e62-4017-b41d-205c0aa82ead"
)

가 실패합니다. "오류: [값] 열이 존재하지 않습니다." 오류. 그 이유는 다음과 같습니다.

큰따옴표 및 이스케이프

PostgreSQL에서는 큰따옴표가 테이블 및 열 이름을 참조하는 이스케이프 문자로 사용됩니다. 실수로 문자열 리터럴과 함께 사용하면 잘못된 구문이 발생할 수 있습니다. 주어진 쿼리에서 IN 목록의 값은 큰따옴표로 묶여 있으며 PostgreSQL은 이를 문자열 상수가 아닌 열 이름으로 해석합니다.

해결책: 값을 작은따옴표로 묶습니다

문제를 해결하려면 값을 작은따옴표로 묶으세요.

DELETE FROM user_job_titles WHERE id IN (
'c836d018-1d12-4507-a268-a4d80d6d3f54',
'd0961a90-7d31-4c4c-9c1b-671115e3d833',
'62dda420-6e62-4017-b41d-205c0aa82ead'
);

이렇게 하면 PostgreSQL은 값을 문자열 상수로 해석하고 비교합니다. user_job_titles 테이블의 id 열과 정확하게 일치합니다.

위 내용은 IN(목록)을 사용할 때 내 PostgreSQL DELETE 쿼리가 '열이 존재하지 않습니다'라는 메시지와 함께 실패하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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