Funktio array_intersect_key
Funktio array_intersect_key ottaa useita taulukoita ja palauttaa uuden taulukon,
joka sisältää ensimmäisen taulukon alkiot, joiden avaimet ovat kaikissa muissa taulukoissa.
Vertailu tapahtuu vain avainten perusteella, arvoja ei oteta huomioon.
Syntaksi
array_intersect_key(array1, array2, array3, ...);
Esimerkki
Verrataan kahta taulukkoa avainten perusteella:
<?php
$arr1 = ['a' => 1, 'b' => 2, 'c' => 3];
$arr2 = ['a' => 4, 'c' => 5, 'd' => 6];
$res = array_intersect_key($arr1, $arr2);
print_r($res);
?>
Koodin suorituksen tulos:
['a' => 1, 'c' => 3]
Esimerkki
Verrataan kolmea taulukkoa avainten perusteella:
<?php
$arr1 = [1 => 'a', 2 => 'b', 3 => 'c'];
$arr2 = [1 => 'd', 3 => 'e'];
$arr3 = [1 => 'f', 4 => 'g'];
$res = array_intersect_key($arr1, $arr2, $arr3);
print_r($res);
?>
Koodin suorituksen tulos:
[1 => 'a']
Esimerkki
Taulukoiden vertailu erityyppisillä avaimilla:
<?php
$arr1 = ['1' => 'a', 2 => 'b'];
$arr2 = [1 => 'c', '2' => 'd'];
$res = array_intersect_key($arr1, $arr2);
print_r($res);
?>
Koodin suorituksen tulos:
['1' => 'a', 2 => 'b']
Katso myös
-
funktion
array_intersect,
joka vertailee taulukoita arvojen perusteella -
funktion
array_diff_key,
joka vertailee taulukoita avainten perusteella ja palauttaa erotuksen -
funktion
array_intersect_assoc,
joka vertailee sekä avaimia että arvoja