mysqli::set_local_infile_handler
mysqli_set_local_infile_handler
(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
Description
Style orienté objet
Style procédural
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
Liste de paramètres
-
link
-
Seulement en style procédural : Un identifiant de lien retourné par la fonction mysqli_connect() ou par la fonction mysqli_init()
-
read_func
-
Une fonction ou une méthode d'objet de rappel prend les paramètres suivants :
-
stream
-
un flux PHP associé avec les commandes SQL INFILE
-
&buffer
-
Une chaîne pour y stocker les données réécrites
-
buflen
-
Le nombre maximal de caractères à stocker dans le buffer
-
&errormsg
-
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.
Valeurs de retour
Cette fonction retourne TRUE
en cas de
succès ou FALSE
si une erreur survient.
Exemples
Exemple #1 Exemple avec mysqli::set_local_infile_handler()
<?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"; } ?>
<?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"; } ?>
Les exemples ci-dessus vont afficher :
Entrée : 23,foo 42,bar Sortie : 23,FOO 42,BAR
Voir aussi
- mysqli_set_local_infile_default() - Rétablit le gestionnaire par défaut pour la commande LOAD LOCAL INFILE