Задать вопрос
@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();
  • Вопрос задан
  • 66 просмотров
Подписаться 2 Простой Комментировать
Помогут разобраться в теме Все курсы
  • Skillfactory
    Профессия Fullstack веб-разработчик на JavaScript и PHP
    20 месяцев
    Далее
  • Хекслет
    PHP-разработчик
    10 месяцев
    Далее
  • Нетология
    Веб-разработчик с нуля: профессия с выбором специализации
    14 месяцев
    Далее
Решения вопроса 1
andead
@andead
друпал девелопер, фрилансер
$alias = $query->addExpression("FIELD(name, 'TEST')", 'order_field');
$query->orderBy($alias, 'DESC');
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

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

Похожие вопросы
FoodSoul Калининград
от 180 000 до 250 000 ₽
IT-Spirit Москва
от 230 000 до 320 000 ₽
от 200 000 до 290 000 ₽