0

这是情况:

购物车属于产品。一个产品属于一个类别。

这是我的查询:

$results = $this->Cart->find('all', 
        array(
          'contain' => array(
                'Product' => array('Category')
                 ),
          'conditions'=>array(
                               'OR' => array(
                                    'Product.title LIKE' => "%$query%", 
                                    'Category.name LIKE' => "%$query%"
                                     )
                             ),                                                  
          'fields'=>array('Product.title', 'Category.name'))

debug($results); exit;

查询无效!!看这个:

 Error: SQLSTATE[42S22]: Column not found: 1054 Unknown column 'Category.name' in 'field list'

SQL Query: SELECT `Product`.`title`, `Category`.`name`, `Product`.`id` FROM `my_db`.`carts` AS `Cart` LEFT JOIN `my_db`.`products` AS `Product` ON (`Cart`.`product_id` = `Product`.`id`) WHERE ((`Product`.`title` LIKE '%apple%') OR (`Category`.`name` LIKE '%apple%')) 

如您所见,类别数据未附加到产品!如果我用一个简单的条件(例如'Category.name LIKE' => "%$query%")尝试相同的查询,则查询有效!所以我认为问题出在 OR 条件上,但我无法解决它......

有建议吗?

提前谢谢

4

2 回答 2

1

由于您尝试在不同表上的术语之间进行 OR,我相信您将不得不放弃此查询的关系并进行手动连接。通过手动加入,我认为您应该能够根据需要编写条件。也许是这样的?

 $this->Cart->recursive = -1;
 $results = $this->Cart->find('all', 
    array(
      'joins' => array(
            array(
                'table' => 'products',
                'alias' => 'Product',
                'conditions' => array(
                    'Product.cart_id = Cart.id',
                ),
            ),
      ),
      'conditions'=>array(
                           'OR' => array(
                                'Product.title LIKE' => "%$query%", 
                                'Category.name LIKE' => "%$query%"
                                 )
                         ),                                                  
      'fields'=>array('Product.title', 'Category.name'));
于 2013-12-04T18:28:16.580 回答
0

您正在应用主模型关联(购物车和产品)中不存在的条件(Category.name)。我不确定您的要求,但一个好的起点是将查询更改为以下内容:

 $results = $this->Cart->find('all', 
        array(
          'contain' => array(
              'Product' => array(
                  'Category' => array(
                      'conditions' => array('Category.name LIKE' => "%$query%"),
                      'fields' => array('Category.name')
                   )
              )
           ),
          'conditions'=>array(
              'Product.title LIKE' => "%$query%"
          ),                                                  
         'fields'=> array('Product.title')
        );

请记住,这不是解决方案,您必须根据您的要求修改条件(如您所见,我删除了 OR 条件)

于 2013-12-04T16:53:21.443 回答