집 >데이터 베이스 >MySQL 튜토리얼 >CSV 파일의 데이터로 Postgres 행을 업데이트하는 방법은 무엇입니까?
CSV 데이터를 사용하여 Postgres 행 업데이트: 단계별 가이드
이 가이드에서는 CSV 파일에서 가져온 데이터를 사용하여 기존 Postgres 행을 업데이트하는 방법을 자세히 설명합니다. 이 프로세스에는 몇 가지 주요 단계가 포함됩니다.
1. 임시 테이블 설치
Postgres 데이터베이스 내에 임시 테이블을 만드는 것부터 시작하세요. 이 테이블은 CSV 데이터의 준비 영역 역할을 합니다. 테이블 스키마는 대상 테이블의 구조를 미러링해야 합니다. 예를 들면 다음과 같습니다.
<code class="language-sql">CREATE TEMP TABLE tmp_x (id int, banana text, apple text);</code>
2. CSV 데이터 가져오기
COPY
명령을 사용하여 CSV 파일의 내용을 임시 테이블에 로드합니다. /absolute/path/to/file
을 실제 파일 경로(
<code class="language-sql">COPY tmp_x FROM '/absolute/path/to/file' (FORMAT csv);</code>
3. 업데이트 수행
임시 테이블의 데이터를 가지고 UPDATE
문을 실행하여 대상 테이블을 수정합니다. 이 예에서는 일치하는 banana
값을 기반으로 id
열을 업데이트합니다.
<code class="language-sql">UPDATE tbl SET banana = tmp_x.banana FROM tmp_x WHERE tbl.id = tmp_x.id;</code>
4. 임시 테이블 제거
업데이트가 완료된 후 임시 테이블을 제거하여 리소스를 회수하세요.
<code class="language-sql">DROP TABLE tmp_x;</code>
중요 사항:
COPY
을 사용하여 데이터를 업데이트하려면 일반적으로 수퍼유저 권한이나 적절하게 할당된 역할이 필요합니다(특히 Postgres 10 이상에서).copy
클라이언트 내의 psql
메타 명령은 수퍼유저 권한이 없는 사용자를 위한 대안을 제공합니다.temp_buffers
증가 및 임시 테이블 인덱싱이 방법은 CSV 파일의 데이터를 사용하여 특정 Postgres 행을 업데이트하는 효율적인 방법을 제공합니다.
위 내용은 CSV 파일의 데이터로 Postgres 행을 업데이트하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!