Executar correspondência de palavras-chave MySQL ORDER BY?
Para isso vamos criar uma tabela, inserir alguns valores e usar ORDER BY CASE. Vamos primeiro criar uma tabela:
mysql> create table DemoTable602 (GameName text);
Query OK, 0 rows affected (0.55 sec)
Insira alguns registros na tabela usando o comando insert:
mysql> insert into DemoTable602 values('Candy cash game');
Query OK, 1 row affected (0.19 sec)
mysql> insert into DemoTable602 values('Pubg');
Query OK, 1 row affected (0.12 sec)
mysql> insert into DemoTable602 values('cash Candy game');
Query OK, 1 row affected (0.15 sec)
mysql> insert into DemoTable602 values('subway');
Query OK, 1 row affected (0.14 sec)
Exiba todos os registros da tabela usando a instrução select:
mysql> select *from DemoTable602;
Isso produzirá a seguinte saída:
+-----------------+
| GameName |
+-----------------+
| Candy cash game |
| Pubg |
| cash Candy game |
| subway |
+-----------------+
4 rows in set (0.00 sec)
A seguir está a consulta para realizar a correspondência de palavras-chave ORDER BY do MySQL:
mysql> select *from DemoTable602
order by
CASE WHEN instr(GameName, 'Candy') = 0 then 1 else 0 end,
instr(GameName, 'cash') desc;
Isso produzirá a seguinte saída:
+-----------------+
| GameName |
+-----------------+
| Candy cash game |
| cash Candy game |
| Pubg |
| subway |
+-----------------+
4 rows in set (0.00 sec)