array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'ja', ), 'this' => array ( 0 => 'function.pg-copy-from.php', 1 => 'pg_copy_from', ), 'up' => array ( 0 => 'ref.pgsql.php', 1 => 'PostgreSQL 関数', ), 'prev' => array ( 0 => 'function.pg-convert.php', 1 => 'pg_convert', ), 'next' => array ( 0 => 'function.pg-copy-to.php', 1 => 'pg_copy_to', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'ja', 'path' => 'reference/pgsql/functions/pg-copy-from.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PHP 4 >= 4.2.0, PHP 5, PHP 7, PHP 8)
pg_copy_from — 配列からテーブルに挿入する
$connection
,$table_name
,$rows
,$separator
= "\t",$null_as
= "\\\\N"
pg_copy_from() は、rows
の内容をテーブルに挿入します。レコードを挿入するために、内部では
COPY FROM
SQL コマンドを発行します。
connection
PgSql\Connection クラスのインスタンス。
table_name
rows
をコピーするテーブルの名前。
rows
table_name
にコピーするデータの配列。
rows
の個々の値が table_name
のひとつの行となります。rows
の個々の値は、
それぞれのフィールドに対応する値が区切り文字で区切られており、最後は
改行で終了していなければなりません。
separator
rows
の要素内で、各フィールドに対応する値を
区切る文字。デフォルトは \t
です。
null_as
rows
の中で、SQL の NULL
をどのように表現するか。デフォルトは \\N
("\\\\N"
) です。
バージョン | 説明 |
---|---|
8.1.0 |
connection は、PgSql\Connection クラスのインスタンスを期待するようになりました。
これより前のバージョンでは、リソース を期待していました。
|
例1 pg_copy_from() の例
<?php
$db = pg_connect("dbname=publisher") or die("Could not connect");
$rows = pg_copy_to($db, $table_name);
pg_query($db, "DELETE FROM $table_name");
pg_copy_from($db, $table_name, $rows);
?>