9

我试图想出一种方法来处理可能非常大的数组集。我正在做的是使用 facebook graph api。

因此,当用户注册我正在构建的服务时,我会将他们的 facebook id 存储在我服务的表中。这样做的目的是让注册我的服务的用户找到他们在 facebook 上的朋友,并且也通过我的服务注册,以便更容易地找到另一个人。

我目前正在尝试做的是获取facebook api为/me/friends数据返回的对象并将其传递给一个函数,我已经为我的数据库构建了一个查询,以查找在FB数据中找到的ID,它工作正常。此外,虽然这一切都在进行,但我已经建立了一系列 facebook id,因此我可以在in_array场景中使用它们。因为我的查询只返回 facebook id 找到的匹配项

虽然这些数据正在循环自身以创建查询,但我还更新了对象以在列表中的每个项目中包含一个键/值对,"are_friends"=> false到目前为止,这一切都运行顺利且相对较快,并且我有我的查询结果. 我正在循环。

所以我处于一个我想避免在循环中出现循环的部分。这就是关键所在in_array()。由于我创建了存储的 fb id 数组,我现在可以遍历我的结果以查看是否存在匹配项,在这种情况下,我想获取我附加的原始对象'are_friends'=>false并更改那些在那个匹配为“真”而不是假的集合中。如果不遍历循环内的原始数组,即结果数组,我想不出一个好方法。

所以我希望有人可以帮助我在这里想出一个没有二级循环的解决方案

到目前为止的数组以原始的样子开始

Array(
    [data](
            [0] => array(
                         are_fb_friends => false
                         name => user name
                         id => 1000
                        )
            [1] => array(
                         are_fb_friends => false
                         name => user name
                         id => 2000
                        )
            [2] => array(
                         are_fb_friends => false
                         name => user name
                         id => 3000
                        )
            )
    )

按要求

这是我当前的代码逻辑,我试图在上面描述..

public function fromFB($arr = array())
{
    $new_arr = array();
    if((is_array($arr))&&(count($arr) > 0))
    {
        $this->db->select()->from(MEMB_BASIC);
        $first_pass = 0;
        for($i=0;$i < count($arr);$i++)
        {
            $arr[$i]['are_fb_friends'] = "false";
            $new_arr[] = $arr[$i]['id'];
            if($first_pass == 0)
            {
                $this->db->where('facebookID', $arr[$i]['id']);
            }
            else
            {
                $this->db->or_where('facebookID', $arr[$i]['id']);
            }
            $first_pass++;
        }
        $this->db->limit(count($arr));
        $query = $this->db->get();
        if($query->num_rows() > 0)
        {
            $result = $query->result();
            foreach($result as $row)
            {
                if(in_array($row->facebookID, $new_arr))
                {
                    array_keys($arr, "blue");
                }
            }
        }
    }
    return $arr;
}
4

1 回答 1

7

要在数组中搜索值并获取其键,可以使用array_search 函数返回元素的键。

$found_key = array_search($needle, $array);

对于 PHP 中的多维数组搜索,请查看https://stackoverflow.com/a/8102246/648044

如果您担心优化,我认为您必须尝试在数据库上使用查询(使用适当的索引)。

顺便问一下,您使用的是Facebook 查询语言吗?如果不试一试,它很有用。

于 2013-03-11T14:52:06.693 回答