2

这是我的模型:

function get_name() {
    $this->db->select('first_name');
    $this->db->where('email', $this->session->userdata('email'));
    $query = $this->db->get('users');

    if($query->num_rows() == 1) {
        return true;
    }
}

这是我的控制器方法:

function show_name() {
    $this->load->model('users_model');
    $this->users_model->get_name();
    }

以及将名称传递给查看的方法:

function profile(){
    $data['first_name'] = $this->show_name();
    $this->load->view('members/template', $data);
}

我在视图中什么都没有,我检查了我的查询,它工作正常。有什么我想念的吗?

4

2 回答 2

5

您需要更新您的代码。您需要first_name从函数返回get_name

function get_name() {
        $this->db->select('first_name');
        $this->db->where('email', $this->session->userdata('email'));
        $query = $this->db->get('users');

        if($query->num_rows() == 1) {
            return $query->row()->first_name;
        }
    }

您还需要return从函数中获取值show_name

function show_name() {
    $this->load->model('users_model');
    return $this->users_model->get_name();
    }
于 2012-12-20T12:08:39.233 回答
1

像这样控制器更改您的代码

function profile(){
    $this->load->model('users_model');
    $name = $this->users_model->get_name();
    if ($name){
      $data['first_name'] = $name;
      $this->load->view('members/template', $data);
    }else{
      ehco "No User Exist";
      exit;
    }
}

模型

function get_name() {
        $return =false;
        $this->db->select('first_name');
        $this->db->where('email', $this->session->userdata('email'));
        $query = $this->db->get('users');

        if($query->num_rows() == 1) {
            $return = $query->row()->first_name;
        }
        return $return ;
    }
于 2012-12-20T12:30:22.053 回答