Dans PHP, lorsque vous utilisez la base de données MySQL, la fonction MySQLI_RESULT :: Fetch_Column peut facilement obtenir une colonne de données dans les résultats de la requête. Combiné avec le modèle d'itérateur de PHP, nous pouvons traverser efficacement de grands ensembles de données et optimiser l'utilisation de la mémoire. Cet article expliquera comment réaliser une traversée efficace des données en utilisant les modèles MySQLI_RESULT :: fetch_column et iterator.
Le modèle d'itérateur est un modèle de conception qui vous permet d'itérer une collection de manière cohérente sans exposer la représentation sous-jacente de la collection. L'interface Iterator de PHP fournit quatre méthodes de base:
Current () : renvoie l'élément actuel.
key () : renvoie le nom de clé de l'élément actuel.
Next () : déplacez le pointeur intérieur vers l'élément suivant.
Valid () : Vérifiez s'il y a un élément valide.
Dans PHP, la fonction MySQLI_RESULT :: Fetch_Column vous permet d'obtenir des données à partir d'une colonne de vos résultats de requête. Il renvoie un tableau contenant toutes les valeurs de la colonne spécifiée. Son utilisation est la suivante:
<span><span><span class="hljs-variable">$result</span></span><span> = </span><span><span class="hljs-variable">$mysqli</span></span><span>-></span><span><span class="hljs-title function_ invoke__">query</span></span><span>(</span><span><span class="hljs-string">"SELECT id, name FROM users"</span></span><span>);
</span><span><span class="hljs-variable">$columnData</span></span><span> = </span><span><span class="hljs-variable">$result</span></span><span>-></span><span><span class="hljs-title function_ invoke__">fetch_column</span></span><span>(</span><span><span class="hljs-number">0</span></span><span>); </span><span><span class="hljs-comment">// Obtenez la première colonne de données</span></span><span>
</span></span>L'utilisation de fetch_column directement pour obtenir toutes les données chargera tous les ensembles de résultats à la fois, ce qui consommera beaucoup de mémoire lorsque les données sont grandes. Afin d'améliorer l'efficacité, en particulier lorsque le volume de données est énorme, les données peuvent être chargées progressivement avec le mode itérateur de PHP, ce qui peut enregistrer la mémoire et améliorer la vitesse de traitement.
Afin de traiter efficacement les données via le modèle d'itérateur, nous pouvons créer une classe pour implémenter l'interface Iterator . Cette classe résumera l'objet mysqli_result et obtiendra progressivement les données de chaque colonne via un itérateur.
Tout d'abord, nous créons une classe MySQLiResulTiterator , qui implémente l'interface Iterator . Cette classe pourra obtenir une ligne de données par ligne à partir de l'objet mysqli_result et utiliser les données fournies par fetch_column .
<span><span><span class="hljs-class"><span class="hljs-keyword">class</span></span></span><span> </span><span><span class="hljs-title">MysqliResultIterator</span></span><span> </span><span><span class="hljs-keyword">implements</span></span><span> </span><span><span class="hljs-title">Iterator</span></span><span> {
</span><span><span class="hljs-keyword">private</span></span><span> </span><span><span class="hljs-variable">$result</span></span><span>;
</span><span><span class="hljs-keyword">private</span></span><span> </span><span><span class="hljs-variable">$column</span></span><span>;
</span><span><span class="hljs-keyword">private</span></span><span> </span><span><span class="hljs-variable">$position</span></span><span>;
</span><span><span class="hljs-keyword">private</span></span><span> </span><span><span class="hljs-variable">$data</span></span><span>;
</span><span><span class="hljs-keyword">public</span></span><span> </span><span><span class="hljs-function"><span class="hljs-keyword">function</span></span></span><span> </span><span><span class="hljs-title">__construct</span></span><span>(</span><span><span class="hljs-params"><span class="hljs-variable">$result</span></span></span><span>, </span><span><span class="hljs-variable">$columnIndex</span></span><span> = </span><span><span class="hljs-number">0</span></span><span>) {
</span><span><span class="hljs-variable language_">$this</span></span><span>->result = </span><span><span class="hljs-variable">$result</span></span><span>;
</span><span><span class="hljs-variable language_">$this</span></span><span>->column = </span><span><span class="hljs-variable">$columnIndex</span></span><span>;
</span><span><span class="hljs-variable language_">$this</span></span><span>->position = </span><span><span class="hljs-number">0</span></span><span>;
</span><span><span class="hljs-variable language_">$this</span></span><span>->data = [];
}
</span><span><span class="hljs-keyword">public</span></span><span> </span><span><span class="hljs-function"><span class="hljs-keyword">function</span></span></span><span> </span><span><span class="hljs-title">rewind</span></span><span>(</span><span><span class="hljs-params"></span></span><span>) {
</span><span><span class="hljs-comment">// Réinitialisez la position de l'itérateur</span></span><span>
</span><span><span class="hljs-variable language_">$this</span></span><span>->position = </span><span><span class="hljs-number">0</span></span><span>;
</span><span><span class="hljs-variable language_">$this</span></span><span>->data = </span><span><span class="hljs-variable language_">$this</span></span><span>->result-></span><span><span class="hljs-title function_ invoke__">fetch_column</span></span><span>(</span><span><span class="hljs-variable">$this</span></span><span>->column);
}
</span><span><span class="hljs-keyword">public</span></span><span> </span><span><span class="hljs-function"><span class="hljs-keyword">function</span></span></span><span> </span><span><span class="hljs-title">current</span></span><span>(</span><span><span class="hljs-params"></span></span><span>) {
</span><span><span class="hljs-comment">// Renvoie les données actuelles</span></span><span>
</span><span><span class="hljs-keyword">return</span></span><span> </span><span><span class="hljs-variable language_">$this</span></span><span>->data[</span><span><span class="hljs-variable language_">$this</span></span><span>->position];
}
</span><span><span class="hljs-keyword">public</span></span><span> </span><span><span class="hljs-function"><span class="hljs-keyword">function</span></span></span><span> </span><span><span class="hljs-title">key</span></span><span>(</span><span><span class="hljs-params"></span></span><span>) {
</span><span><span class="hljs-comment">// Renvoie le nom clé de l'élément actuel</span></span><span>
</span><span><span class="hljs-keyword">return</span></span><span> </span><span><span class="hljs-variable language_">$this</span></span><span>->position;
}
</span><span><span class="hljs-keyword">public</span></span><span> </span><span><span class="hljs-function"><span class="hljs-keyword">function</span></span></span><span> </span><span><span class="hljs-title">next</span></span><span>(</span><span><span class="hljs-params"></span></span><span>) {
</span><span><span class="hljs-comment">// Déplacez le pointeur intérieur vers l'élément suivant</span></span><span>
++</span><span><span class="hljs-variable language_">$this</span></span><span>->position;
}
</span><span><span class="hljs-keyword">public</span></span><span> </span><span><span class="hljs-function"><span class="hljs-keyword">function</span></span></span><span> </span><span><span class="hljs-title">valid</span></span><span>(</span><span><span class="hljs-params"></span></span><span>) {
</span><span><span class="hljs-comment">// Vérifiez si l'élément actuel est valide</span></span><span>
</span><span><span class="hljs-keyword">return</span></span><span> </span><span><span class="hljs-keyword">isset</span></span><span>(</span><span><span class="hljs-variable language_">$this</span></span><span>->data[</span><span><span class="hljs-variable language_">$this</span></span><span>->position]);
}
}
</span></span>Une fois la classe Itérator créée, nous pouvons facilement l'utiliser pour itérer à travers une colonne de données dans les résultats de la requête MySQL. Voici comment l'implémenter:
<span><span><span class="hljs-variable">$mysqli</span></span><span> = </span><span><span class="hljs-keyword">new</span></span><span> </span><span><span class="hljs-title function_ invoke__">mysqli</span></span><span>(</span><span><span class="hljs-string">"localhost"</span></span><span>, </span><span><span class="hljs-string">"username"</span></span><span>, </span><span><span class="hljs-string">"password"</span></span><span>, </span><span><span class="hljs-string">"database"</span></span><span>);
</span><span><span class="hljs-keyword">if</span></span><span> (</span><span><span class="hljs-variable">$mysqli</span></span><span>->connect_error) {
</span><span><span class="hljs-keyword">die</span></span><span>(</span><span><span class="hljs-string">"Connection failed: "</span></span><span> . </span><span><span class="hljs-variable">$mysqli</span></span><span>->connect_error);
}
</span><span><span class="hljs-variable">$query</span></span><span> = </span><span><span class="hljs-string">"SELECT id, name FROM users"</span></span><span>;
</span><span><span class="hljs-variable">$result</span></span><span> = </span><span><span class="hljs-variable">$mysqli</span></span><span>-></span><span><span class="hljs-title function_ invoke__">query</span></span><span>(</span><span><span class="hljs-variable">$query</span></span><span>);
</span><span><span class="hljs-comment">// Créer une instance itérateur,Obtenir "id" Données de colonne(L'indice de colonne est0)</span></span><span>
</span><span><span class="hljs-variable">$iterator</span></span><span> = </span><span><span class="hljs-keyword">new</span></span><span> </span><span><span class="hljs-title class_">MysqliResultIterator</span></span><span>(</span><span><span class="hljs-variable">$result</span></span><span>, </span><span><span class="hljs-number">0</span></span><span>);
</span><span><span class="hljs-comment">// Itérer et sortir tous ID données</span></span><span>
</span><span><span class="hljs-keyword">foreach</span></span><span> (</span><span><span class="hljs-variable">$iterator</span></span><span> </span><span><span class="hljs-keyword">as</span></span><span> </span><span><span class="hljs-variable">$key</span></span><span> => </span><span><span class="hljs-variable">$value</span></span><span>) {
</span><span><span class="hljs-keyword">echo</span></span><span> </span><span><span class="hljs-string">"ID: <span class="hljs-subst">$value</span></span></span><span>\n";
}
</span><span><span class="hljs-variable">$mysqli</span></span><span>-></span><span><span class="hljs-title function_ invoke__">close</span></span><span>();
</span></span>Dans cet exemple, nous traversons la première colonne de données dans le résultat de la requête via mysqliresulterator et sortions chaque ligne d'identification par ligne. Le mode itérateur nous permet d'accéder progressivement aux données sans charger l'ensemble de données à la fois, en évitant le problème de la consommation excessive de mémoire.
Combiné avec le modèle d'itérateur, la fonction Fetch_Column nous aide non seulement à obtenir des données plus efficacement, mais nous permet également de charger des données étape par étape au lieu de charger toutes les données en mémoire à la fois. Ceci est très utile pour gérer de grandes quantités de données, en particulier lorsque la mémoire est limitée.
En combinant MySQLI_RESULT :: Fetch_Column et PHP Iterator, nous pouvons implémenter une traversée efficace des résultats de la requête MySQL. Le mode itérateur fournit un moyen économe en mémoire d'éviter de charger le résultat de la requête entier à la mémoire à la fois. L'utilisation de ce modèle, la maintenabilité et les performances de votre code peuvent être améliorées lors du traitement de grandes quantités de données.
Étiquettes associées:
mysqli_result