L'opération SELECT * INTO OUTFILE de MySQL permet l'exportation des données de la table vers un fichier texte sur la machine serveur. Cependant, lorsque le fichier cible doit être localisé sur un hôte autre que le serveur, SELECT INTO OUTFILE n'est pas une option. La documentation MySQL suggère d'utiliser une commande telle que mysql -e "SELECT ..." > file_name à la place.
Fait intéressant, bien que LOAD DATA INFILE puisse être modifié en LOAD DATA LOCAL INFILE pour spécifier un fichier local, il n'existe pas d'équivalent SELECT INTO OUTFILE LOCAL. Cette limitation soulève la question de savoir pourquoi cette fonctionnalité n'est pas disponible.
Le manuel MySQL explique que SELECT ... INTO OUTFILE est principalement destiné au vidage rapide des données sur la machine serveur. Pour transférer des données vers un hôte client, l'approche recommandée consiste à utiliser une commande telle que celle mentionnée ci-dessus.
En résumé, SELECT INTO OUTFILE de MySQL est limité à la création de fichiers locaux, tandis que LOAD DATA LOCAL INFILE offre une flexibilité pour récupérer des données à partir de fichiers locaux. Bien que les raisons derrière cette décision de conception ne soient pas explicitement abordées dans la documentation, elle garantit des pratiques de traitement des données sécurisées en limitant le transfert de données en dehors de l'environnement du serveur.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!