我对Codeigniter很陌生。我有一个问题,似乎我的查询不起作用。是因为我的格式吗?
模型
$this->db->select('*');
$this->db->from('
store_products,
products,
category,
subcategory,
store,
store_products_category');
$this->db->where('store_products_category.store_id', $marketid);
$this->db->where('store_products_category.subcategory_id', 'subcategory.subcategory_id');
$this->db->where('subcategory.category_id', 'category.category_id');
$this->db->where('store_products_category.storeprod_id', 'store_products.storeprod_id');
$this->db->where('store_products.prod_id', 'products.prod_id');
$this->db->where('store_products_category.store_id', 'store.store_id');
$query = $this->db->get();
$result = $query->row();
return $result;
控制器
if($marketinfo = $this->MarketModel->getInfobyID($marketid)){
$data['marketinfolist'] = $marketinfo;
$this->load->view('layouts/header', $data);
$this->load->view('clickbasket',$data);
$this->load->view('navigation/mainfooter');
$this->load->view('layouts/footer');
}
它似乎无法从模型中返回任何内容。我已经尝试过直接在phpmyadmin上执行查询,它工作得很好。
最佳答案
你需要加入表格才能得到正确的结果…就像这样。。
您的型号:
$query = $this->db->select('*')
->from('store_products')
->join('products', 'store_products.prod_id = products.prod_id')
->join('store_products_category', 'store_products_category.storeprod_id = store_products.storeprod_id')
->join('subcategory', 'store_products_category.subcategory_id = subcategory.subcategory_id');
->join('category', 'subcategory.category_id = category.category_id')
->join('store', 'store_products_category.store_id = store.store_id')
->where('store_products_category.store_id', $marketid)
->get();
$result = $query->row();
return $result;
在你的控制器。。
function getMarketInfo($marketid)
{
if(!empty($marketid)){
$marketinfo = $this->MarketModel->getInfobyID($marketid);
$data['marketinfolist'] = $marketinfo;
$this->load->view('layouts/header', $data);
$this->load->view('clickbasket',$data);
$this->load->view('navigation/mainfooter');
$this->load->view('layouts/footer');
}
}
关于php - CodeIgniter SQL正确格式,用于从不同表中获取数据,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/41343872/