次のクエリがあります。
SELECT
*
FROM
`Magic The Gathering`
WHERE
`set` = 'Magic 2013'
ORDER BY
(CASE
WHEN `cost` LIKE '%B%' THEN 1
WHEN `cost` LIKE '%R%' THEN 2
WHEN `cost` LIKE '%G%' THEN 3
WHEN `cost` LIKE '%W%' THEN 4
WHEN `cost` LIKE '%U%' THEN 5
WHEN `cost` LIKE '%B%U%' THEN 6
ELSE 7
END),
FIELD (`rarity`, 'Mythic', 'Rare', 'Uncommon', 'Common', 'Land') ASC,
(CASE
WHEN `type` LIKE '%Planeswalker%' THEN 1
WHEN `type` LIKE '%Creature%' THEN 2
WHEN `type` LIKE '%Instant%' THEN 3
WHEN `type` LIKE '%Sorcery%' THEN 4
WHEN `type` LIKE '%Enchantment%' THEN 5
WHEN `type` LIKE '%Artifact%' THEN 6
WHEN `type` LIKE '%Land%' THEN 7
END)
LIMIT
500
ラインを見ると…
WHEN `cost` LIKE '%B%U%' THEN 6
両方をサポートするようにするにはどうすればよいですか
WHEN `cost` LIKE '%B%U%' THEN 6
と
WHEN `cost` LIKE '%U%B%' THEN 6
U が B の前にあることに注目してください。
WHEN `cost` LIKE '%B%U%G%R%' THEN 6
基本的に、これらの文字のいずれかが順序に関係なく文字列に含まれていれば、機能するはずです。これどうやってするの?