ホームページ > データベース > mysql チュートリアル > MySQL で条件に基づいてさまざまな列ごとにデータを並べ替えるにはどうすればよいですか?

MySQL で条件に基づいてさまざまな列ごとにデータを並べ替えるにはどうすればよいですか?

DDD
リリース: 2024-11-16 02:09:02
オリジナル
428 人が閲覧しました

How to Order Data By Different Columns Based on a Condition in MySQL?

条件に基づいて異なる列で並べ替える方法

MySQL では、条件に基づいて異なる列でデータを並べ替えることができますSQL 関数または CASE ステートメントを使用します。

IF を使用する関数:

ORDER BY 句で IF 関数を使用するには、カンマで区切られた 2 つの式を指定できます。最初の式は、どの式を使用するかを決定する条件です。 2 番目の式は、条件が true の場合に使用する値です。

例:

ORDER BY IF(TYPE='Member', LNAME, GROUPNAME) ASC
ログイン後にコピー

このステートメントは、TYPE 列が ' に等しい場合、LNAME 列によってデータを並べ替えます。 Member' を使用し、TYPE 列が 'Group' と等しい場合は GROUPNAME 列を使用します。

CASE ステートメント:

CASE ステートメントは、条件に基づいてさまざまな列ごとにデータを並べ替える、より柔軟なオプションです。複数の条件と対応する式を指定できます。

例:

ORDER BY 
    CASE `type` 
        WHEN 'Member' THEN LNAME 
        WHEN 'Group' THEN GROUPNAME
        ELSE 1 END 
    ASC
ログイン後にコピー

このステートメントでは、type 列が ' に等しい場合、データは LNAME 列によって並べ替えられます。 「メンバー」。タイプ列が「グループ」と等しい場合は GROUPNAME 列によって、それ以外の場合は値 1 によって決まります。

以上がMySQL で条件に基づいてさまざまな列ごとにデータを並べ替えるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート