>  기사  >  백엔드 개발  >  PHP 배열에서 여러 값을 쿼리하는 방법

PHP 배열에서 여러 값을 쿼리하는 방법

PHPz
PHPz원래의
2023-04-18 09:06:05611검색

웹 개발에서는 배열을 쿼리해야 하는 경우가 많습니다. 때로는 배열의 여러 값을 쿼리해야 할 경우 하나씩 검색하면 시간이 많이 걸리고 노동 집약적일 뿐만 아니라 비효율적입니다. 그리고 PHP는 배열의 여러 값을 쿼리하는 쉬운 방법을 제공합니다.

먼저 아래와 같이 쿼리할 배열을 정의해야 합니다.

$array = array("red", "blue", "green", "yellow", "white", "black");

이 배열에서 여러 값을 쿼리해야 한다고 가정합니다. 예를 들어 "red", "blue"를 쿼리해야 합니다. 그리고 배열에 "검은색"이 있으면 PHP의 array_intersect() 함수를 사용하여 이를 달성할 수 있습니다. array_intersect() 函数来实现。

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

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

$to_query = array("red", "blue", "black");

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

$result = array_intersect($array, $to_query);

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

print_r($result);

输出结果如下:

Array
(
    [0] => red
    [1] => blue
    [5] => black
)

可以看到,我们查询到了数组中的 "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")
);

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

$to_query = array("age" => array(19, 22), "gender" => "M");

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

然后就可以使用 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);

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

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

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

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

print_r($result);

输出结果如下:

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

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

)

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

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

이 함수는 두 개 이상의 배열을 허용하고 모든 배열에 포함된 요소를 포함하는 새 배열을 반환할 수 있습니다. 🎜🎜array_intersect() 함수를 사용하여 여러 값을 쿼리하는 방법을 살펴보겠습니다. 먼저 여러 값을 배열로 구성합니다: 🎜rrreee🎜 그런 다음 array_intersect() 함수를 사용하여 이 배열의 여러 값을 쿼리할 수 있습니다. 🎜rrreee🎜 이런 식으로 우리는 $result 쿼리에 필요한 여러 값을 배열에서 가져올 수 있습니다. print_r() 함수를 사용하여 $result 배열을 출력할 수 있습니다. 🎜rrreee🎜출력 결과는 다음과 같습니다. 🎜rrreee🎜보시다시피 " 빨간색", "파란색"과 "검은색"의 세 가지 값입니다. 출력 결과의 배열 첨자는 원래 배열의 첨자와 동일합니다. 🎜🎜위에서 언급했듯이 array_intersect() 함수는 여러 배열을 허용하므로 한 번에 여러 값 집합을 쿼리할 수도 있습니다. 🎜🎜더 복잡한 예를 살펴보겠습니다. 여러 사용자에 대한 정보가 포함된 연관 배열이 있다고 가정해 보겠습니다. 🎜rrreee🎜이제 나이가 19세 또는 22세이고 성별이 남성인 사용자에 대한 정보를 쿼리해야 합니다. 쿼리할 조건을 연관 배열로 구성할 수 있습니다. 🎜rrreee🎜 이 배열의 첫 번째 요소는 쿼리할 두 개의 연령 값을 포함하는 배열입니다. 두 번째 요소는 쿼리할 성별 값입니다. 🎜🎜그런 다음 array_intersect() 함수를 사용하여 쿼리할 수 있습니다. 🎜rrreee🎜여기서 array_query() 함수를 사용자 정의했습니다. 이 함수는 두 개의 매개변수를 받습니다. 첫 번째 매개변수는 쿼리할 배열이고 두 번째 매개변수는 쿼리할 조건입니다. 🎜🎜함수는 내부적으로 PHP의 array_filter() 함수와 익명 함수를 사용하여 배열을 필터링합니다. 입력 쿼리 조건 $to_query의 경우 함수는 먼저 이 조건에 따라 조건을 충족하는 배열 요소를 필터링합니다. 🎜🎜그런 다음 그 결과를 쿼리 결과 $result로 반환합니다. 🎜🎜마지막으로 print_r() 함수를 사용하여 쿼리 결과를 출력할 수 있습니다. 🎜rrreee🎜출력 결과는 다음과 같습니다. 🎜rrreee🎜보시다시피 우리는 두 개의 사용자 정보를 성공적으로 쿼리했습니다. 조건을 충족합니다. 🎜🎜실제 개발에서는 배열에 대해 다중 값 쿼리를 수행해야 하는 경우가 많습니다. 이 함수는 PHP의 array_intersect() 함수를 사용하여 쉽게 구현할 수 있습니다. 또한 필요에 따라 이를 추가로 캡슐화하고 필요에 맞는 기능을 구축할 수도 있습니다. 🎜

위 내용은 PHP 배열에서 여러 값을 쿼리하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.