CASE または IF ELSEIF を使用した MySQL Select ステートメント: 動的領域可視化のための正しいパスの選択
このシナリオには、2 つのテーブルがあります。 1 つは地域制限を含むメーカー情報、もう 1 つは製品の詳細です。目標は、メーカーの設定に基づいて製品を表示できる地域を動的に決定することです。
クエリの中心となるのは、CASE ステートメントまたは IF ELSEIF ステートメントを使用するかの決定です。どちらのアプローチでも、条件ステートメントに基づいて動的な値を提供できます。
CASE ステートメント: 複雑な条件ロジックの簡素化
クエリで、CASE ステートメントを使用して次のことを試みました。製品の状態 (新品または中古) と、メーカーの表から対応する露出値を評価します。ただし、CASE ステートメントは、真の条件に関係なく、常に最初の値を返します。
これを解決するには、CASE ステートメントを次のように変更します。
CASE status WHEN 'New' THEN t2.expose_new WHEN 'Used' THEN t2.expose_used ELSE NULL END as 'expose'
この拡張された CASE ステートメントは、製品を正しく評価します。
IF ELSEIF の使用: ステップバイステップ評価
または、IF ELSEIF ステートメントを使用して同じ結果を得ることができます。ただし、このアプローチでは、考えられる各条件を評価するために一連の IF ステートメントが必要です。
SELECT t2.company_name, t2.expose_new, t2.expose_used, t1.title, t1.seller, t1.status, IF(status = 'New', t2.expose_new, IF(status = 'Used', t2.expose_used, 1)) as 'expose' FROM `products` t1 JOIN manufacturers t2 ON t2.id = t1.seller WHERE t1.seller = 4238
この IF ELSEIF 構造体はステータス条件を順番に評価し、適切な露出値を返します。
最終的に、 CASE と IF ELSEIF のどちらを選択するかは、条件付きロジックの複雑さによって異なります。単純なロジックの場合、CASE ステートメントは簡潔で読みやすいアプローチを提供します。より複雑なシナリオの場合、IF ELSEIF ステートメントを使用すると、複数の条件をより柔軟に処理できます。
以上がMySQL の CASE または IF ELSEIF: 動的な領域の可視化にはどちらが最適ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。