
pg_query를 사용하여 데이터를 삽입할 때 에러가 발생하는 이유는, 데이터베이스의 유니크 제약 조건에 의해 발생하는 것입니다. 유니크 제약 조건은 테이블에 동일한 키 값을 가진 행이 존재할 수 없도록 제한하는 규칙입니다.
에러 메시지인 "duplicate key value violates unique constraint \"my_table_pkey\""는, 키 값이 이미 존재하는 테이블에 동일한 키 값을 가진 행을 삽입하려고 한다는 것을 의미합니다.
pg_query의 insert문을 사용할 때, 중복된 키 값을 처리하는 방법은 다음과 같습니다.
1. 중복된 키 값을 허용하지 않기: 유니크 제약 조건을 설정하여 중복된 키 값을 허용하지 않습니다. 이 방법은 데이터베이스의 유니크 제약 조건을 설정하는 것과 같습니다.
2. 중복된 키 값을 업데이트 하기: 중복된 키 값을 가진 행이 이미 존재하는 경우, 기존의 행을 업데이트하여 새로운 데이터를 삽입합니다. 이 방법은 `ON CONFLICT` 절을 사용하여 수행할 수 있습니다.
3. 중복된 키 값을 무시하기: 중복된 키 값을 가진 행이 이미 존재하는 경우, 새로운 데이터를 삽입하지 않습니다. 이 방법은 `ON CONFLICT DO NOTHING` 절을 사용하여 수행할 수 있습니다.
pg_query의 insert문에서 `ON CONFLICT` 절을 사용하는 예제는 다음과 같습니다.
#hostingforum.kr
sql
INSERT INTO my_table (id, name)
VALUES (1, 'John')
ON CONFLICT (id) DO UPDATE SET name = EXCLUDED.name;
이 예제는 중복된 키 값을 가진 행이 이미 존재하는 경우, 기존의 행을 업데이트하여 새로운 데이터를 삽입합니다.
2025-04-04 02:09