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

时间:2013-02-02 20:53:46

标签: php fatal-error

我在我的网站上为我的群组编写了以下代码..

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。

1 个答案:

答案 0 :(得分:0)

在错误行中$ db为null,因为 $ db尚未在函数中声明 set_group_id()。
我只看到数据库对象 $ db2

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

尝试将$ db替换为$ db2。如果$ db2包含正确的数据库对象和打开连接的句柄,它将起作用