Доктрина - или где?
У меня есть следующий запрос:
$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'
.
Ответы
Ответ 1
$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.
Ответ 2
Ответ Tom является правильным, хотя мне нравится свести повторение/дублирование кода до минимума.
Этот способ также должен работать, будучи более коротким, более чистым способом сделать это
$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');