0

Codeigniter 不返回数据库结果。数据库表“类别”和“子类别”

DB舍玛:

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

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

  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 ;       
}

出了什么问题我一直有数据库错误或空白页面。

4

2 回答 2

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();
于 2013-02-18T19:03:01.200 回答
0

根据你的问题,这听起来像是你想多了,但我也有点困惑。我听到的是:如何根据点击主类别 ID 的人获取子类别?如果是这种情况,那么您将其变得比需要的复杂得多。

模型

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();
}

}
于 2013-02-18T16:56:00.957 回答