@MikUrrey

Drupal 8: как выполнить ORDER BY FIELD в конструкторе запроса?

Есть запрос в таксономию, нужно отсортировать результаты так, чтобы определенные оказались внизу.
В MySQL это было бы так: ORDER BY FIELD(name, "TEST") DESC.
Как добавить такое в нижеследующий код?
use Drupal\Core\Database\Database;
///////
$connection = Database::getConnection();
$query = $connection->select('taxonomy_term_field_data', 'data');
$query->fields('data', ['tid', 'name'])
      ->condition('vid', 'themes')
      ->orderBy('name')
      ->execute();
  • Вопрос задан
  • 57 просмотров
Решения вопроса 1
andead
@andead
друпал девелопер, фрилансер
$alias = $query->addExpression("FIELD(name, 'TEST')", 'order_field');
$query->orderBy($alias, 'DESC');
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы
19 апр. 2024, в 13:31
10000 руб./за проект
19 апр. 2024, в 13:12
35000 руб./за проект
19 апр. 2024, в 13:06
6000 руб./за проект