(PHP 5)
mysqli::set_local_infile_handler -- mysqli_set_local_infile_handler — Définit une fonction de rappel pour la commande LOAD DATA LOCAL INFILE
Style orienté objet (méthode)
Définit une fonction de rappel pour la commande LOAD DATA LOCAL INFILE.
Le but de la fonction de rappel est de lire le fichier spécifié par LOAD DATA LOCAL INFILE et de le reformater dans un format compris par LOAD DATA INFILE.
Les données retournées doivent correspondre au format spécifié par LOAD DATA
Style procédural uniquement : Un identifiant de lien retourné par la fonction mysqli_connect() ou par la fonction mysqli_init()
Une fonction ou une méthode d'objet de rappel prend les paramètres suivants :
un flux PHP associé avec les commandes SQL INFILE
Une chaîne pour y stocker les données réécrites
Le nombre maximal de caractères à stocker dans le buffer
Si une erreur survient, vous pourrez stocker le message d'erreur ici
La fonction de rappel doit retourner le nombre de caractères stockés dans le buffer ou une valeur négative si une erreur survient.
Cette fonction retourne TRUE en cas de succès, FALSE en cas d'échec.
Exemple #1 Style orienté objet
<?php
$db = mysqli_init();
$db->real_connect("localhost","root","","test");
function callme($stream, &$buffer, $buflen, &$errmsg)
{
$buffer = fgets($stream);
echo $buffer;
// convertit en majuscule et remplace le délimiteur "," par [TAB]
$buffer = strtoupper(str_replace(",", "\t", $buffer));
return strlen($buffer);
}
echo "Entrée :\n";
$db->set_local_infile_handler("callme");
$db->query("LOAD DATA LOCAL INFILE 'input.txt' INTO TABLE t1");
$db->set_local_infile_default();
$res = $db->query("SELECT * FROM t1");
echo "\nSortie :\n";
while ($row = $res->fetch_assoc()) {
echo join(",", $row)."\n";
}
?>
Exemple #2 Style procédural
<?php
$db = mysqli_init();
mysqli_real_connect($db, "localhost","root","","test");
function callme($stream, &$buffer, $buflen, &$errmsg)
{
$buffer = fgets($stream);
echo $buffer;
// convertit en majuscule et remplace le délimiteur "," par [TAB]
$buffer = strtoupper(str_replace(",", "\t", $buffer));
return strlen($buffer);
}
echo "Entrée :\n";
mysqli_set_local_infile_handler($db, "callme");
mysqli_query($db, "LOAD DATA LOCAL INFILE 'input.txt' INTO TABLE t1");
mysqli_set_local_infile_default($db);
$res = mysqli_query($db, "SELECT * FROM t1");
echo "\nSortie :\n";
while ($row = mysqli_fetch_assoc($res)) {
echo join(",", $row)."\n";
}
?>
L'exemple ci-dessus va afficher :
Entrée : 23,foo 42,bar Sortie : 23,FOO 42,BAR