致命错误:对中的非对象调用成员函数fetch()


Fatal error: Call to a member function fetch() on a non-object in

我在下面为我的站点中的小组编写了这段代码。。

public function set_group_id($group_id)
    {
        $db2        = & $this->network->db2;
        /* if( $this->id ) {
            return FALSE;
        } */
        if( ! $group_id ) {
            return FALSE;
        }
        if( ! $g = $this->network->get_group_by_id($group_id) ) {
            return FALSE;
        }
        if( !$g->is_public && $this->user->id>0 && !$this->user->is_network_admin ) {
            $users  = $this->network->get_group_invited_members($g->id);
            if( !$users || !in_array(intval($this->user->id),$users) ) {
                return FALSE;
            }
        }
         $D->i_am_network_admin  = ( $this->user->is_logged && $this->user->info->is_network_admin > 0 );
         $D->i_am_admin      = $D->i_am_network_admin;
         if( !$D->i_am_network_admin ) {
         $D->i_am_admin  = $db->fetch('SELECT id FROM groups_admins WHERE group_id="'.$g->id.'" AND user_id="'.$this->user->id.'" LIMIT 1') ? TRUE : FALSE;
         }

        if( $g->mojaz && !$this->user->i_am_admin  ) {
            return FALSE;
        }
        $this->group    = $g;
        $this->to_user  = FALSE;
        return TRUE;
    }

我这行的错误。。。

             $D->i_am_admin  = $db->fetch('SELECT id FROM groups_admins WHERE group_id="'.$g->id.'" AND user_id="'.$this->user->id.'" LIMIT 1') ? TRUE : FALSE;

我想为网站组创建限制器,如果用户是网站管理员,他可以发送帖子或者如果用户是组管理员,可以发送帖子,否则返回false。

在您的错误行$db为null,因为函数set_group_id()中没有声明$db
我只看到数据库对象$db2

$db2 =& $this->network->db2

尝试将$db重新部署到$db2。如果$db2包含正确的数据库对象和打开连接的句柄,它将在

中工作