篝火codeigniter链式模型方法

时间:2013-02-03 18:31:39

标签: php codeigniter

我只是篝火/ ci的新手。我试图通过链接bf / ci模型方法重新创建以下sql语句:

        SELECT  prod_cat.cat_id, 
                prod_cat.prod_id, 
                prod.enabled, 
                prod.name,
                prod.prod_id,   
        FROM prod_cat, prod 
        WHERE prod.is_enabled = 1 
        AND prod_cat.cat_id =15 
        AND prod_cat.prod_id = prod.prod_id 
        ORDER BY prod.name DESC

我有一个bf / ci prod_model和一个prod_cat_model。

我知道我可以执行以下操作来获取与cat_id 15匹配的所有产品,例如:

 $this->load->model('cat/prod_cat_model');  
 $records = $this->prod_cat_model->find_all_by('cat_id' => $cid);

同样,我计划在产品表上使用find_all_by来限制活动/启用的记录,如下所示:

 $this->prod_model->find_all_by('enabled', 1);

首先,作为一个测试,我试图通过将数组传递给prod_model来尝试将这两个代码组合起来,如下所示:

  public function productsincategory($cid)
  {
    $this->load->model('cat/prod_cat_model');   
    $criteria = array(
    'enabled' => 1,
    'prod_id' => $this->prod_cat_model->find_all_by('cat_id', $cid)
    );
    $records = $this->prod_model->find_all_by($criteria) ;
  }

我收到一条错误消息:

  

'where子句'中的未知列'Array'

     

SELECT * FROM(prod)WHERE enabled = 1 AND prod_id = Array

这是有道理的...但我不知道如何修复它,所以它就像“select * from prod where enabled = 1 and prod_id in(prod id from prod_cat table) 我也尝试过使用“where_in()”,但这似乎并没有被篝火识别出来。 谢谢。

1 个答案:

答案 0 :(得分:0)

我在我的产品模型中创建了自己的where_in()方法,如下所示:

public function where_in($field=NULL, $value=NULL)
{
    if (!empty($field))
    {
        if (is_string($field))
        {
            $this->db->where_in($field, $value);
        }
        else if (is_array($field))
        {
            $this->db->where($field);
        }
    }

    return $this;

}//end where()

所以在我的控制器中,我做了这样的事情:

  public function productsincategory($cid)
  {
    $this->load->model('cat/prod_cat_model');  
    $this->prod_cat_model->where('cat_id', $cid);
    $records = $this->prod_cat_model->find_all();

 $prod_ids = array();

foreach($records as $record)
{
    array_push($prod_ids, $record->product_id);
}

    $this->prod_model->where_in('prod_id', $prod_ids) ; //call our own where_in method
$records = $this->prod_model->find_all();
  }
相关问题