CakePHP, Установка сложного / множественного условия поиска для поля множественного выбора - PullRequest
0 голосов
/ 04 января 2010

У меня есть поле с несколькими вариантами выбора с именем Производитель, которое отображается правильно, даже для интерактивного поиска. Когда я запускаю поиск, я не получаю никаких результатов из своей базы данных, используя сложные условия поиска, которые я установил. Я пытался использовать сложные условия поиска из пекарни и других веб-сайтов, но безрезультатно.

//This my index.ctp
<?=$form->create('ManufacturersProductsLine', array('action'=>'index'));?>
    <table width="100%" border="0" cellspacing="0" cellpadding="0">
        <tr>
            <td>
                <?=$f->label('ManufacturersProductsLine.manufacturer_id', 'Manufacturer Name:'); ?>
                <?=$f->select('ManufacturersProductsLine.manufacturer_id', $manufacturers, null, array('multiple'=>'multiple', 'style'=>'height:100px;'))?>
            </td>
            <td>
                <?=$f->label('ManufacturersProductsLine.name', 'Product Name:'); ?>
                <?=$f->text('ManufacturersProductsLine.name', array('style'=>'width:140px;'));?>
            </td>
            <td>
                <label></label>
                <input name="Search" class="blue" type="submit" value="Search Product Lines" />
            </td>
        </tr>
    </table>

Закомментировано то, что я пытался в своем контроллере для установки условий множественного поиска.

//This is my manufacturers_products_lines_controller.php
function index() {
    $conditions = array();
    if (!empty($this->data)) {
        $data = $this->data;

        $conditions[] = "(LOWER(ManufacturersProductsLine.manufacturer_id) LIKE '%{$data['ManufacturersProductsLine']['manufacturer_id']}%')";
        //$conditions = array("ManufacturersProductsLine.name" => array("Akuret", "Bridgestone", "American Radials") );

        debug($this->data);
    }
    $this->Manufacturer->recursive = 1;
    $this->set('manufacturersproductslines', $manufacturersproductslines = $this->paginate('ManufacturersProductsLine', $conditions));
    $Manufacturer = getModel('Manufacturer');
    $this->set('manufacturers', $Manufacturer->find('list'));
    //$this->ManufacturersProductsLine->recursive = 0;
    //$this->Post->find('all', array('conditions' => array('ManufacturersProductsLine.manufacturer_id' =>array(0,1,2,3,4,5,6,7,8,9,10,11,12,13))));

}

При отладке и поиске получаю следующее.

Array
(
[ManufacturersProductsLine] => Array
    (
        [manufacturer_id] => Array
            (
                [0] => 1
                [1] => 2
            )

        [name] => 
    )
)

1 Ответ

1 голос
/ 05 января 2010

попробуйте изменить условие запроса на

$conditions[] = "ManufacturersProductsLine.manufacturer_id IN (" . implode( ',', $data['ManufacturersProductsLine']['manufacturer_id'] . ")";
...