Rechercher une fonction PHP

mysqli: : set _local _infile _handler

mysqli _set _local _infile _handler

(PHP 5, PHP 7)

mysqli::set_local_infile_handler -- mysqli_set_local_infile_handlerDéfinit une fonction de rappel pour la commande LOAD DATA LOCAL INFILE

  

Description

Style orienté objet

bool mysqli::set_local_infile_handler ( mysqli $link , callable $read_func )

Style procédural

bool mysqli_set_local_infile_handler ( mysqli $link , callable $read_func )

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()

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";
  }
?>

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";
  }
?>

Les exemples ci-dessus vont afficher :

Entrée :
23,foo
42,bar

Sortie :
23,FOO
42,BAR

  

Voir aussi

Rechercher une fonction PHP

Version en cache

05/11/2024 09:34:04 Cette version de la page est en cache (à la date du 05/11/2024 09:34:04) afin d'accélérer le traitement. Vous pouvez activer le mode utilisateur dans le menu en haut pour afficher la dernère version de la page.

Document créé le 30/01/2003, dernière modification le 26/10/2018
Source du document imprimé : https://www.gaudry.be/php-rf-mysqli.set-local-infile-handler.html

L'infobrol est un site personnel dont le contenu n'engage que moi. Le texte est mis à disposition sous licence CreativeCommons(BY-NC-SA). Plus d'info sur les conditions d'utilisation et sur l'auteur.

Références

  1. Consulter le document html Langue du document :fr Manuel PHP : http://php.net

Ces références et liens indiquent des documents consultés lors de la rédaction de cette page, ou qui peuvent apporter un complément d'information, mais les auteurs de ces sources ne peuvent être tenus responsables du contenu de cette page.
L'auteur de ce site est seul responsable de la manière dont sont présentés ici les différents concepts, et des libertés qui sont prises avec les ouvrages de référence. N'oubliez pas que vous devez croiser les informations de sources multiples afin de diminuer les risques d'erreurs.

Table des matières Haut