Учение - или где? - PullRequest
       1

Учение - или где?

14 голосов
/ 30 июля 2011

У меня следующий запрос:

$query = Doctrine_Query::create()
                ->from('Member m')
                    ->where("m.type='1'")
                        ->andWhere("m.name LIKE '%$term%'")
                        ->orWhere("m.surname LIKE '%$term%'")
                        ->orWhere("m.company LIKE '%$term%'")
                        ->orderBy('id DESC');

Но он работает не так, как я хочу - он игнорирует type столбец.

Мне нужен набор результатов, где m.type=1и некоторые другие поля в этом запросе LIKE 'something'.

Ответы [ 2 ]

20 голосов
/ 31 июля 2011

Ответ Тома правильный, хотя мне нравится сводить повторение / дублирование кода к минимуму.

Этот способ также должен работать, будучи более коротким и чистым способом

$query = Doctrine_Query::create()
       ->from('Member m')
       ->where('m.type = ?', 1)
       ->andWhere('m.name LIKE :term OR m.surname LIKE :term OR m.company LIKE :term', array(':term' => '%' . $term . '%'))
       ->orderBy('m.id DESC');
20 голосов
/ 31 июля 2011
$query = Doctrine_Query::create()
  ->from('Member m')
  ->where('m.type = 1 AND m.name LIKE ?', '%'.$term.'%')
  ->orWhere('m.type = 1 AND m.surname LIKE ?', '%'.$term.'%')
  ->orWhere('m.type = 1 AND m.company LIKE ?', '%'.$term.'%')
  ->orderBy('m.id DESC');

Ваши условия OR не включают первое условие.Также рекомендуется использовать ? для ваших переменных, чтобы Doctrine избежал их.

...