I bench-marked some uses of array_intersect and can't believe how slow it is. This isn't as elaborate, but handles most cases and is much faster:
<?php
function simple_array_intersect($a,$b) {
$a_assoc = $a != array_values($a);
$b_assoc = $b != array_values($b);
$ak = $a_assoc ? array_keys($a) : $a;
$bk = $b_assoc ? array_keys($b) : $b;
$out = array();
for ($i=0;$i<sizeof($ak);$i++) {
if (in_array($ak[$i],$bk)) {
if ($a_assoc) {
$out[$ak[$i]] = $a[$ak[$i]];
} else {
$out[] = $ak[$i];
}
}
}
return $out;
}
?>
You can try this out with this:
<?php
$first = array();
for ($i=500;$i<500000;$i++) {
$first[] = $i;
}
$second = array();
for ($i=499990;$i<500000;$i++) {
$second[$i] = rand();
}
echo microtime(true)."\n";
print_r(array_intersect($first,$second));
echo microtime(true)."\n";
print_r(simple_array_intersect($first,$second));
echo microtime(true)."\n";
print_r(simple_array_intersect($second,$first));
echo microtime(true)."\n";
?>