ScotlandPHP

PDO::pgsqlCopyFromArray

(PHP 5 >= 5.3.3, PHP 7)

PDO::pgsqlCopyFromArrayCopiar datos de un array de PHP a una tabla

Descripción

public bool PDO::pgsqlCopyFromArray ( string $table_name , array $rows [, string $delimiter = '\t' [, string $null_as = "\\\\N" [, string $fields ]]] )

Copia los datos del array rows a la tabla table_name empleando delimiter como delimitador de campos y la lista de campos fields

Parámetros

table_name

Una cadena que contiene el nombre de la tabla

rows

Un array de cadenas con los campos separados por delimiter

delimiter

El delimitador empleado en el array rows

null_as

Cómo interpretar valores nulos

fields

El listado de campos a insertar

Valores devueltos

Devuelve TRUE en caso de éxito, o FALSE en caso de error.

add a note add a note

User Contributed Notes 1 note

up
1
Anonymous
2 years ago
If your $nullAs is '\\N', then you should use $nullAs as is in concatenation of cells of $rows, but send to pgsqlCopyFromArray() escaped version. Also fifth arg $fields should be a SQL-valid string for the column_names placeholder in COPY statement of PostgreSQL.

I provide my smart wrapper for pgsqlCopyFromArray() which do this automatically.

<?php
/**
*
* @param PDO $db
* @param string $tableName
* @param string[] $fields List of fields names.
* @param array[] $records Two-demension array of cells (array of rows).
* @return boolean
*/
function pgInsertByCopy (PDO $db, $tableName, array $fields, array $records) {
    static
$delimiter = "\t", $nullAs = '\\N';

   
$rows = [];

    foreach (
$records as $record) {
       
$record = array_map(
                function  (
$field) use( $record, $delimiter, $nullAs) {
                   
$value = array_key_exists($field, $record) ? $record[$field] : null;

                    if (
is_null($value)) {
                       
$value = $nullAs;
                    } elseif (
is_bool($value)) {
                       
$value = $value ? 't' : 'f';
                    }

                   
$value = str_replace($delimiter, ' ', $value);
                   
// Convert multiline text to one line.
                   
$value = addcslashes($value, "\0..\37");

                    return
$value;
                },
$fields);
       
$rows[] = implode($delimiter, $record) . "\n";
    }

    return
$db->pgsqlCopyFromArray($tableName, $rows, $delimiter, addslashes($nullAs), implode(',', $fields));
}
?>
To Top