【问题标题】:Codeigniter query for selecting sum of multiple columns with where conditions on each rowCodeigniter 查询,用于选择多列的总和,每行具有 where 条件
【发布时间】:2019-08-01 12:36:36
【问题描述】:

我已经制作了这个函数来获取基于 group_id 的人口百分比总和为 1,2 和 3,但它不起作用

public function ethnicity($value='')
        {
            $this->db->select('SUM(population_percent) as p1 where group_id=1,SUM(population_percent) as p2 where group_id=2,SUM(population_percent) as p3 where group_id=3', FALSE);
            $this->db->from('ethnic_group');
            $data=$this->db->get()->row_array();
                return $data;
        }

【问题讨论】:

  • 你不能在select中通过where参考CI活动记录指南。

标签: mysql codeigniter activerecord


【解决方案1】:

在这种情况下需要sum时需要使用IFCASE

使用此查询

public function ethnicity($value='')
{
    $sql = "SELECT  
              SUM(CASE WHEN group_id='1' THEN population_percent ELSE 0 END) p1,
              SUM(CASE WHEN Type='2' THEN population_percent ELSE 0 END) p2,
              SUM(CASE WHEN Type='3' THEN population_percent ELSE 0 END) p3,
            FROM ethnic_group LIMIT 1";


    $data = $this->db->query($sql)->row_array();
    return $data;
}

【讨论】:

  • 有用的可以采纳,其他的也可以参考一下。
【解决方案2】:

当您使用$this->db->select() 时,您正在编写查询的“选择”部分。要编写“位置”,您应该使用$this->db->where('group_id=3')

如果你想编写一个完整的查询并告诉 CodeIgniter 运行它,你可以使用 $this->db->query($sql)$sql 作为你想要运行的实际查询 as seen in the documentation here

所以我认为它应该是这样的:

 $sql = 'your query here';
 $data = $this->db->query($sql)->row_array();
 return $data;

【讨论】:

  • 先生,我将数据存储在基于 group_id 的表中,我想在单个查询中获取三个组的所有这三个组的人口总数。
  • 我认为 Devsi Odedra 的回答解决了查询和 CodeIgniter 问题。试试看。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2017-09-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-07-11
  • 2020-08-29
相关资源
最近更新 更多