Codeigniter JOIN不要回db结果

时间:2013-02-18 16:43:59

标签: codeigniter

Codeigniter不支持数据库结果。 数据库表“类别”和“子类别”

DB Shema:

Categor
-----------------------------
ID     Name 
----------------------------
1      Fishing
2      Hunting
3      Test Category

Sub_category
-----------------------------
ID     cat_id      name
----------------------------
1      1          Fishing rod
2      2          Hunting ammunition
3      3          Test sub category

我想列出某个类别的所有子类别。当有人点击钓鱼类别时我想要显示钓鱼的所有子类别。我的代码是这样的:

  Controller:
       public function get_sub_category($id = 0)
        {
            $this->load->model('front_m');    
            $data['sub_cat'] = $this->front_m->show_sub_cat($id);          
            $this->template->set_theme('zend')->set_layout('front.html')
                           ->build('sub_category',$data); 
    }
  MODEL:

    public function show_sub_cat($id=0)
{
    $this->query = $this->db->select('*');
    $this->query = $this->db->from('category');
            $this->query = $this->db->where('id='.$id');
    $this->query = $this->db->join('sub_category', 'sub_category.cat_id=category.id');
    $this->query = $this->db->query('SELECT * FROM category');
    $this->query = $this->db->get();

    if ($this->query->num_rows() > 0) {
        $this->query->result();
    }
    return $this->query ;       
}

什么是wron我总是有DB错误或空白页。

2 个答案:

答案 0 :(得分:0)

根据你的问题,这听起来像你在想它,但我也有点困惑。我听到的是:如何根据点击主类别ID的人来获取我的子类别?如果是这种情况那么你的制作方式就比它需要的更复杂。

MODEL

public function show_sub_cat($catid=NULL)
{
$result = $this->db->get_where('sub_category',array('cat_id'=>$catid));
if ($result->num_rows()>0)
{
return $result->result();
}

}

答案 1 :(得分:0)

$sql_query  ="SELECT 
                c.name,
                sc.*
             FROM Category as c
             LEFT JOIN Sub_category as sc ON sc.cat_id = c.ID
             WHERE c.ID = $id";
return $this->db->query($sql_query)->result();