如何在codeigniter中获取数据库列的总和?

时间:2014-09-23 09:44:06

标签: php codeigniter

朋友我无法获得空缺职位。这是我的代码。我得到1(一)而不是总和。帮我解决这个问题。

控制器:

function index(){
    $userId = $this->phpsession->get("userId");
    $userType = $this->phpsession->get('userType');
    $date = date("Y-m-d");
    if(!$userId && !$this->phpsession->get("userType")){
        redirect(base_url().'user');
    }

    $config['base_url'] = base_url().'requirement/index';
    $config['total_rows'] = $this->requirement_model->GetRequirement(array("count"=>true));
    $config['per_page'] = 5;
    $config['cur_tag_open'] = '<a>';
    $config['cur_tag_close'] = '</a>';

    $this->pagination->initialize($config);

    $options['offset'] = $this->uri->segment(3);
    $options['limit'] = $config['per_page'];        
    $options['join']=true;

    $data['clients'] = $this->client_model->ajaxclient();
    $data['requirements'] = array(""=>"Choose requirement");

    $data['requirement'] = $this->requirement_model->GetRequirement($options);
    $data['links'] = $this->pagination->create_links();
    $data['totalactive']=$this->requirement_model->GetRequirement(array("find"=>true));
    $data['totalrequirement']=$this->requirement_model->GetRequirement(array("totalreq"=>true));
    $data['openpositions']=$this->requirement_model->GetRequirement(array("openpos"=>true));
    //print_R($data['openpositions']);exit;
    //echo "<pre>"; print_R($this->db->last_query()); exit;

    $data['page_title'] = "Requirement Details";
    $this->layout->view("requirement/index",$data); 

}

这是我的模特函数

型号:

function GetRequirement($ options = array()){         如果(isset($选项[ 'requirementId']))             $这 - &GT; DB-化合物其中( 'requirementId',$选项[ 'requirementId']);

    if(isset($options['clientName']))
        $this->db->where('clientName',$options['clientName']);  

    if(isset($options['limit']) && isset($options['offset']))
        $this->db->limit($options['limit'], $options['offset']);
    else if(isset($options['limit']))
        $this->db->limit($options['limit']);

    $this->db->order_by("activateddate", "DESC");

    if(isset($options['join'])){

        $this->db->select('r.*,c.clientName as cName');
        $this->db->from('requirement as r');
        $this->db->join('clients as c','c.clientId=r.clientName');
        $query=$this->db->get();
        if(@$options['requirementId']) return $query->row(0);
        return $query->result();
    }

    if(isset($options['find'])){
        $this->db->select('distinct(clientName)');
        $this->db->from('requirement');
        $this->db->where('(clientName) and (noofpositions > 0) ');
        $this->db->count_all();
        $query=$this->db->get();
        return $query->num_rows();  
    }

    if(isset($options['totalreq'])){
        $this->db->select('requirementName');
        $this->db->from('requirement');
        $this->db->where('(noofpositions > 0) ');
        $this->db->count_all();
        $query=$this->db->get();
        return $query->num_rows();  
    }


    if(isset($options['openpos'])){
        $this->db->select_sum('openPos');   
        $this->db->from('requirement'); 
        $this->db->where('(closedPos = 0) ');   
        $this->db->count_all();
        $query=$this->db->get();
        return $query->num_rows();
    }

    $query = $this->db->get('requirement');

    if(isset($options['count'])) return $query->num_rows();

    if(@$options['requirementId']) return $query->row(0);

    return $query->result();
}

这是我的查看页面

查看:

<div class="inner">
    <h3><?php echo $openpositions; ?></h3>
     <p>Total Positions Opened</p>
</div>

2 个答案:

答案 0 :(得分:4)

您正在使用sum这是一个汇总函数,并且按照它的分组将整个表格作为模型代码的if(isset($options['openpos'])){ ... }部分中的一个组,您将返回num_rows()返回号码。在你的情况下,行将有一行的值为sum,因此你得到的结果是1改变你的

if (isset($options['openpos'])) {
    $this->db->select_sum('openPos');
    $this->db->from('requirement');
    $this->db->where('(closedPos = 0) ');
    $query = $this->db->get();
    return $query->row()->openpos;
}

答案 1 :(得分:2)

我认为mysql语句有错误。

更改以下行:

 $this->db->where('(closedPos = 0) ');   

$this->db->where('closedPos', 0);   

删除以下行:(这将计算所有行并返回您不想要的值)

 $this->db->countall(); 

如果这不能解决您的问题,您可以尝试通过添加exit($ this-&gt; db-&gt; last_query())来输出mysql语句;尝试找到问题,像这样:

     if(isset($options['openpos'])){
        $this->db->select_sum('openPos');   
        $this->db->from('requirement'); 
        $this->db->where('(closedPos = 0) ');   
        $this->db->count_all();
        $query=$this->db->get();

        // output last query
        exit($this->db->last_query());

        return $query->num_rows();

    }
相关问题