Codeigniter - 在同一模型中调用模型方法是错误的

时间:2012-06-14 15:10:14

标签: php sql codeigniter query-builder

我试图在同一个模型中调用模型方法,但它没有按预期工作。这是我的班级有两种不起作用的方法

class mymodel extends CI_Model{
    public function __construct(){
        parent::__construct();
        $this->tablea = 'tablea';
        $this->tableb = 'tableb';
    }

    public function saveData($data){
        $dataCopy['revisionkey'] = $this->getRevisionKey($data['id']);
        //check and condition revision key to be int with +1 from last one
        $this->db->insert($this->tableb, $dataCopy);
        $this->db->where('id', $id);
        return $this->db->update($this->user_table, $data) ? true : false;
    }

    public function getRevisionKey($id){
        $this->db->select($this->revision_tablea.'.revisions_number as revisions_number')
            ->from($this->revision_tablea)
            ->where($this->revision_tablea.'.id', $id)
            ->order_by($this->revision_table.'.revisions_number', 'asc')
            ->limit(1);
        $query = $this->db->get();
        if ($query->num_rows() > 0){
            return $query->row_array();
        }else{
            return 0;
        }
    }
}

现在方法getRevisionKey()应该产生如下的查询

SELECT `tableb`.`revisions_number` as revisions_number FROM (`tableb`) WHERE `tableb`.`id` = '26' ORDER BY `tableb`.`revisions_number` asc LIMIT 1

但它产生如下的查询

SELECT `tableb`.`revisions_number` as revisions_number FROM (`tableb`) WHERE `id` = '26' AND `tableb`.`id` = '26' ORDER BY `tableb`.`revisions_number` asc LIMIT 1

这当然是由于在模型中调用相同的方法,如果在模型外部使用,此方法可以正常工作。解决这个问题的方法是什么?

修改 重写getRevisionKey()修复此问题。这是新版本

    public function getRevisionKey($id){
        $sqlQuery = $this->db->select($this->revision_tablea.'.revisions_number as revisions_number')
            ->from($this->revision_tablea)
            ->order_by($this->revision_table.'.revisions_number', 'asc')
            ->limit(1);
        $query = $sqlQuery->where($this->revision_tablea.'.id', $id)->get();
        if ($query->num_rows() > 0){
            return $query->row_array();
        }else{
            return 0;
        }
    }

1 个答案:

答案 0 :(得分:0)

这是一个简单的黑客攻击,可以准确地告诉你出错的地方。 转到system / database / DB_active_rec.php从这些函数中删除public或protected关键字

public function _compile_select($select_override = FALSE)
public function _reset_select()

并保存。在运行该函数之前,我的意思是调用

$this->db->get() // Use $this->db->from() instead

使用

$query = $this->db->_compile_select()

和echo $ query;

这两个函数也有助于codeigniter活动记录中的子查询。 How can I rewrite this SQL into CodeIgniter's Active Records?