当前代码不会返回所有行。
例如,如果某些产品没有类别或用户活动从所选行中排除。
如何使用一个查询简化该查询?
有没有办法用多个联盟或任何其他(简单)方式来做?
$q = $this->db->select('products.id, users_activity.timestamp AS added, products_content.lang, products_content.product_name, products_content.price, products_categories_content.category_name AS category, products_categories_content.category_id AS category_id')
->from('products')
->join('products_content', 'products.id = products_content.product_id')
->join('products_and_categories', 'products.id = products_and_categories.product_id')
->join('products_categories_content', 'products_categories_content.category_id = products_and_categories.category_id')
->join('users_activity', 'users_activity.id = products.id AND users_activity.lang = products_content.lang')->where('users_activity.type', 'product')
->group_by(array('products.id', 'products_content.lang', 'users_activity.id'))
->limit($limit, $offset)
->order_by($sort_by, $sort_order);
if (strlen($query_array['lang']) && ! is_numeric($query_array['lang'])) { $q->like('lang', $query_array['lang']); }
if (strlen($query_array['product_name'])) { $q->like('product_name', $query_array['product_name']); }
if (strlen($query_array['category'])) { $q->where('category_id', $query_array['category']); }
$return['rows'] = $q->get()->result();
答案 0 :(得分:2)
默认情况下,CI会创建内部联接。如果两个表中都有记录,则内部联接仅查找结果。因此,如果产品没有类别,则此语句不会返回任何记录。
$this->db->join('products_and_categories', 'products.id = products_and_categories.product_id');
将此联接更改为左联接,并且将始终返回产品,即使它们没有类别。
$this->db->join('products_and_categories', 'products.id = products_and_categories.product_id', left);