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错误或空白页。
答案 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();