我正在尝试让 mysql 查询进入 Code Igniter 的 Active Record 语法,但有点困难。
查询是这个问题的结果:Multiple mysql ORDER BY's for multidimensional ordering/grouping
我尝试自己格式化查询,解决了几个错误,但不确定如何进行。我必须向自己添加该get_compiled_select()功能DB_active_rec.php并将其_reset_select()从受保护更改为公共以使其完全运行。
建议的查询是:
select
  t.id,
  t.group,
  t.date,
  t.comlete
from
  YourTable t
  left join
    (select
      m.group,
      min(m.date) as mindate,
      min(t.complete) as groupcomplete
    from
      YourTable m) mt on mt.group = t.group
order by
  coalesce(mt.groupcomplete, t.complete),
  coalesce(mt.mindate, t.date),
  t.group,
  t.complete,
  t.date
我的翻译看起来像这样(请注意,原文中没有“where”子句,而“date”实际上是“due”):
        // Sub query
        $this->db->select('m.group, min(m.due) as mindate, min(t.complete) as groupcomplete');
        $this->db->from('task m');
        $this->db->where('property', $property);
        $subquery = $this->db->get_compiled_select();
        $this->db->_reset_select();
        // Main query
        $this->db->select('*');
        $this->db->where('property', $property);
        $this->db->from('task t');
        $this->db->join('($subquery) mt','mt.group = t.group');
        $this->db->order_by('coalesce(mt.groupcomplete, t.complete)');
        $this->db->order_by('coalesce(mt.mindate, t.due)');
        $this->db->order_by('t.group');
        $this->db->order_by('t.complete');
        $this->db->order_by('t.due');
        $query = $this -> db -> get();
        // Return
        return $query->result();
不幸的是,这只是抛出一个错误:
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'mt ON `mt`.`group` = `t`.`group` WHERE `property` = '7' ORDER BY coalesce(mt.gr' at line 3
CI 报告的查询如下所示:
SELECT * FROM (`task` t) JOIN ($subquery) mt ON `mt`.`group` = `t`.`group` WHERE `property` = '7' ORDER BY coalesce(mt.groupcomplete, `t`.`complete)`, coalesce(mt.mindate, `t`.`date)`, `t`.`due`, `t`.`complete`, `t`.`date`
任何人都可以就如何正确格式化此格式提供一些建议?不幸的是,我的 mysql 技能非常简单,所以这正在推动我的能力。我的大部分翻译方法来自 Stack Overflow 上的答案,因为我没有以这种方式组合查询的经验(与子查询)。