Упорядочивание по одному и тому же столбцу в таблице с другим порядком сортировки в зависимости от условия с использованием querybuilder

У меня есть таблица, где мне нужно проверить условие во время выполнения оператора select для этой таблицы, основываясь на условии, что мне нужно изменить условие заказа. Как этого добиться с помощью построителя запросов (Doctrine). пример: имя таблицы -> продукт

<table>
  <tr>
    <th>pid</th>
    <th>Lastname</th> 
    <th>instock</th>
    <th>laststock</th> 
    <th>price</th>
  </tr>
  <tr>
    <td>two</td>
    <td>234</td> 
    <td>1</td>
        <td>1</td> 
    <td>101</td>
  </tr>
  <tr>
    <td>three</td>
    <td>345</td> 
    <td>0</td>
        <td>1</td> 
    <td>102</td>
  </tr>
  <tr>
    <td>four</td>
    <td>567</td> 
    <td>2</td>
        <td>1</td> 
    <td>103</td>
  </tr>
  <tr>
    <td>five</td>
    <td>678</td> 
    <td>0</td>
        <td>0</td> 
    <td>104</td>
  </tr>
  <tr>
    <td>one</td>
    <td>123</td> 
    <td>3</td>
        <td>0</td> 
    <td>100</td>
  </tr>
</table>

поэтому в этой таблице мне нужно сначала проверить стоимость товара, если он больше нуля, мне нужно упорядочить его в порядке DESC (столбец товара). иначе мне нужно заказать в порядке ASC (столбец на складе). Как это сделать с помощью построителя запросов?

Мне нужен вывод, как это

<table style="width: 100%;">
<tbody>
<tr>
<th>pid</th>
<th>Lastname</th>
<th>instock</th>
<th>laststock</th>
<th>price</th>
</tr>
<tr>
<td>one</td>
<td>123</td>
<td>3</td>
<td>0</td>
<td>100</td>
</tr>
  <tr>
<td>four</td>
<td>567</td>
<td>2</td>
<td>1</td>
<td>103</td>
</tr>
  <tr>
<td>two</td>
<td>234</td>
<td>1</td>
<td>1</td>
<td>101</td>
</tr>
  <tr>
<td>three</td>
<td>345</td>
<td>0</td>
<td>1</td>
<td>102</td>
</tr>
  <tr>
<td>five</td>
<td>678</td>
<td>0</td>
<td>0</td>
<td>104</td>
</tr>
</tbody>
</table>

Что я пробовал

$query->addOrderBy(($query->expr()->neq('variant.instock', 0)), 'DESC')
    ->addOrderBy(($query->expr()->eq('variant.instock', 0)) , 'ASC');

В конце концов это вызовет SQL-запрос, как показано ниже

SELECT * FROM product ORDER BY instock <> 0 DESC, instock = 0 ASC

и дать вывод, как это

<table style="width: 100%;">
<tbody>
<tr>
<th>pid</th>
<th>Lastname</th>
<th>instock</th>
<th>laststock</th>
<th>price</th>
</tr>
  <tr>
<td>two</td>
<td>234</td>
<td>1</td>
<td>1</td>
<td>101</td>
</tr>
    <tr>
<td>four</td>
<td>567</td>
<td>2</td>
<td>1</td>
<td>103</td>
</tr>
  <tr>
<td>one</td>
<td>123</td>
<td>3</td>
<td>0</td>
<td>100</td>
</tr>
  <tr>
<td>three</td>
<td>345</td>
<td>0</td>
<td>1</td>
<td>102</td>
</tr>
  <tr>
<td>five</td>
<td>678</td>
<td>0</td>
<td>0</td>
<td>104</td>
</tr>
</tbody>
</table>

1 ответ

Ваш код Sql может быть как ниже

  SELECT * FROM product ORDER BY case when instock = 0 then 0 else 1 end 
Другие вопросы по тегам