Maison > développement back-end > Problème PHP > Comment interroger plusieurs valeurs dans un tableau php

Comment interroger plusieurs valeurs dans un tableau php

PHPz
Libérer: 2023-04-18 09:26:41
original
664 Les gens l'ont consulté

En développement web, il est souvent nécessaire d'interroger des tableaux. Parfois, nous devons interroger plusieurs valeurs dans un tableau. Si nous recherchons une par une, cela prendra non seulement beaucoup de temps et de main-d'œuvre, mais également inefficace. Et PHP fournit un moyen simple d'interroger plusieurs valeurs dans un tableau.

Tout d'abord, nous devons définir un tableau à interroger, comme indiqué ci-dessous :

$array = array("red", "blue", "green", "yellow", "white", "black");
Copier après la connexion

Supposons que nous devions interroger plusieurs valeurs​​dans ce tableau, par exemple, nous devons interroger "rouge", "bleu" et "black" dans le tableau, nous pouvons utiliser la fonction array_intersect() de PHP pour y parvenir. array_intersect() 函数来实现。

该函数可以接受两个或多个数组,返回一个包含所有数组都包含的元素的新数组。

让我们来看看如何使用 array_intersect() 函数来查询多个值。我们首先将多个值组成一个数组:

$to_query = array("red", "blue", "black");
Copier après la connexion

然后我们就可以使用 array_intersect() 函数来查询这个数组中的多个值了:

$result = array_intersect($array, $to_query);
Copier après la connexion

这样,我们就可以在 $result 数组中获得我们需要查询的多个值。可以使用 print_r() 函数来输出 $result 数组:

print_r($result);
Copier après la connexion
Copier après la connexion

输出结果如下:

Array
(
    [0] => red
    [1] => blue
    [5] => black
)
Copier après la connexion

可以看到,我们查询到了数组中的 "red"、"blue" 和 "black" 这三个值。注意,输出结果的数组下标与原数组中的下标相同。

正如上面所说的,array_intersect() 函数可以接受多个数组,因此我们也可以一次查询多组值。

让我们看看一个更复杂的例子。假设我们有一个关联数组,其中包含了多个用户的信息:

$users = array(
    array("name" => "Tom", "age" => 20, "gender" => "M"),
    array("name" => "Jack", "age" => 22, "gender" => "M"),
    array("name" => "Mary", "age" => 21, "gender" => "F"),
    array("name" => "Lucy", "age" => 19, "gender" => "F")
);
Copier après la connexion

现在,我们需要查询出年龄为 19 岁或 22 岁,性别为男性的用户信息。我们可以将待查询的条件组成一个关联数组:

$to_query = array("age" => array(19, 22), "gender" => "M");
Copier après la connexion

这个数组中的第一个元素是一个数组,包括了两个待查询的年龄值;第二个元素是待查询的性别值。

然后就可以使用 array_intersect() 函数来查询了:

function array_query($array, $to_query) {
    return array_filter($array, function ($item) use ($to_query) {
        foreach ($to_query as $key => $value) {
            if (!in_array($item[$key], (array)$value)) {
                return false;
            }
        }
        return true;
    });
}

$result = array_query($users, $to_query);
Copier après la connexion

我们这里自定义了一个 array_query() 函数。该函数接受两个参数,第一个参数是待查询的数组,第二个参数是待查询的条件。

函数内部使用了 PHP 的 array_filter() 函数和匿名函数来对数组进行过滤。对于输入的查询条件 $to_query,该函数首先根据这个条件来筛选符合条件的数组元素。

然后,将结果返回给查询结果 $result

最后,我们可以使用 print_r() 函数来输出查询结果:

print_r($result);
Copier après la connexion
Copier après la connexion

输出结果如下:

Array
(
    [0] => Array
        (
            [name] => Tom
            [age] => 20
            [gender] => M
        )

    [1] => Array
        (
            [name] => Jack
            [age] => 22
            [gender] => M
        )

)
Copier après la connexion

可以看到,我们成功查询到了符合条件的两个用户信息。

在实际开发中,我们经常需要对数组进行多值查询。使用 PHP 中的 array_intersect()

Cette fonction peut accepter deux tableaux ou plus et renvoyer un nouveau tableau contenant les éléments contenus dans tous les tableaux. 🎜🎜Voyons comment interroger plusieurs valeurs à l'aide de la fonction array_intersect(). Nous formons d'abord plusieurs valeurs dans un tableau : 🎜rrreee🎜 Ensuite, nous pouvons utiliser la fonction array_intersect() pour interroger plusieurs valeurs​​dans ce tableau : 🎜rrreee🎜 De cette façon, nous peut $result Obtenez les multiples valeurs que nous devons interroger dans le tableau. Vous pouvez utiliser la fonction print_r() pour afficher le tableau $result : 🎜rrreee🎜Les résultats de sortie sont les suivants : 🎜rrreee🎜Comme vous pouvez le voir, nous avons interrogé " rouge", Les trois valeurs "bleu" et "noir". Notez que l'index du tableau du résultat de sortie est le même que l'index du tableau d'origine. 🎜🎜Comme mentionné ci-dessus, la fonction array_intersect() peut accepter plusieurs tableaux, nous pouvons donc également interroger plusieurs ensembles de valeurs à la fois. 🎜🎜Regardons un exemple plus complexe. Supposons que nous ayons un tableau associatif contenant des informations sur plusieurs utilisateurs : 🎜rrreee🎜Maintenant, nous devons interroger les informations de l'utilisateur dont l'âge est de 19 ou 22 ans et dont le sexe est de sexe masculin. Nous pouvons former les conditions à interroger dans un tableau associatif : 🎜rrreee🎜Le premier élément de ce tableau est un tableau, comprenant deux valeurs d'âge à interroger ; 🎜🎜Ensuite, vous pouvez utiliser la fonction array_intersect() pour interroger : 🎜rrreee🎜Nous avons personnalisé une fonction array_query() ici. Cette fonction accepte deux paramètres, le premier paramètre est le tableau à interroger et le deuxième paramètre est la condition à interroger. 🎜🎜La fonction utilise en interne la fonction array_filter() de PHP et la fonction anonyme pour filtrer le tableau. Pour la condition de requête d'entrée $to_query, la fonction filtre d'abord les éléments du tableau qui répondent à la condition en fonction de cette condition. 🎜🎜Ensuite, renvoyez le résultat au résultat de la requête $result. 🎜🎜Enfin, nous pouvons utiliser la fonction print_r() pour afficher les résultats de la requête : 🎜rrreee🎜Les résultats de sortie sont les suivants : 🎜rrreee🎜Comme vous pouvez le voir, nous avons réussi à interroger deux informations utilisateur qui remplit les conditions. 🎜🎜Dans le développement réel, nous devons souvent effectuer des requêtes multi-valeurs sur des tableaux. Cette fonction peut être facilement implémentée en utilisant la fonction array_intersect() en PHP. De plus, nous pouvons également l'encapsuler davantage en fonction de nos besoins et créer des fonctions adaptées à nos propres besoins. 🎜

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal