
PDO::pgsqlCopyFromArray 메서드는 PostgreSQL 데이터베이스에 데이터를 복사하는 데 사용됩니다. 이 메서드의 사용법을 설명드리겠습니다.
데이터 타입을 지정하는 방법은 다음과 같습니다.
- 문자열 타입: PDO::pgsqlCopyFromArray 메서드는 문자열 타입을 자동으로 인식합니다. 따라서, 칼럼의 데이터 타입을 지정할 필요가 없습니다.
- 숫자 타입: 숫자 타입을 지정하려면, 칼럼의 데이터 타입을 지정할 필요가 있습니다. 예를 들어, `column2`의 데이터 타입이 숫자일 때, `column2`에 `INT` 또는 `INTEGER`를 지정할 수 있습니다.
데이터를 복사하는 동안, 데이터베이스에 이미 존재하는 데이터를 업데이트하는 방법은 다음과 같습니다.
- `ON CONFLICT` 문을 사용하여, 데이터베이스에 이미 존재하는 데이터를 업데이트할 수 있습니다. 예를 들어, `ON CONFLICT (column1) DO UPDATE SET column2 = EXCLUDED.column2`를 사용할 수 있습니다.
예시 코드를 다음과 같이 수정할 수 있습니다.
#hostingforum.kr
php
$stmt = $pdo->prepare('COPY table1(column1, column2) FROM STDIN WITH CSV HEADER');
$stmt->execute(array('data1', 123)); // column1은 문자열, column2는 숫자
또한, `ON CONFLICT` 문을 사용하여 데이터를 업데이트할 수 있습니다.
#hostingforum.kr
php
$stmt = $pdo->prepare('COPY table1(column1, column2) FROM STDIN WITH CSV HEADER ON CONFLICT (column1) DO UPDATE SET column2 = EXCLUDED.column2');
$stmt->execute(array('data1', 123));
이러한 방법으로, PDO::pgsqlCopyFromArray 메서드를 사용하여 PostgreSQL 데이터베이스에 데이터를 복사하고, 데이터베이스에 이미 존재하는 데이터를 업데이트할 수 있습니다.
2025-07-05 04:56