条件式
条件式を使用すると、フィルター、注釈、集計、および更新内でif
…elif
…else
ロジックを使用できます。 条件式は、テーブルの各行の一連の条件を評価し、一致する結果式を返します。 条件式は、他の式のように組み合わせてネストすることもできます。
条件式クラス
以降の例では、次のモデルを使用します。
When
- class When(condition=None, then=None, **lookups)
When()
オブジェクトは、条件式で使用するための条件とその結果をカプセル化するために使用されます。 When()
オブジェクトの使用は、 filter()メソッドの使用と同様です。 条件は、フィールドルックアップ、 Q オブジェクト、または BooleanField [であるoutput_field
を持つ Expression オブジェクトを使用して指定できます。 X161X]。 結果は、then
キーワードを使用して提供されます。
いくつかの例:
これらの値はそれぞれ式である可能性があることに注意してください。
バージョン3.2で変更: lookups
でcondition
引数を使用するためのサポートが追加されました。
Case
- class Case(*cases, **extra)
Case()
式は、Python
のif
…elif
…else
ステートメントのようなものです。 提供されたWhen()
オブジェクトの各condition
は、真の値に評価されるまで、順番に評価されます。 一致するWhen()
オブジェクトからのresult
式が返されます。
例:
Case()
は、任意の数のWhen()
オブジェクトを個別の引数として受け入れます。 その他のオプションは、キーワード引数を使用して提供されます。 どの条件もTRUE
と評価されない場合、default
キーワード引数で指定された式が返されます。 default
引数が指定されていない場合は、None
が使用されます。
以前のクエリを変更して、Client
の使用期間に基づいて割引を取得したい場合は、ルックアップを使用して行うことができます。
ノート
条件は順番に評価されるため、上記の例では、2番目の条件がJaneDoeとJackBlackの両方に一致していても、正しい結果が得られることに注意してください。 これは、Python
のif
…elif
…else
ステートメントと同じように機能します。
Case()
はfilter()
句でも機能します。 たとえば、1か月以上前に登録したゴールドクライアントと1年以上前に登録したプラチナクライアントを検索するには、次のようにします。
高度なクエリ
条件式は、注釈、集計、フィルター、ルックアップ、および更新で使用できます。 また、他の式と組み合わせてネストすることもできます。 これにより、強力な条件付きクエリを作成できます。
条件付き集計
account_type
ごとにクライアントがいくつあるかを知りたい場合はどうなりますか? 集計関数のfilter
引数を使用して、これを実現できます。
この集計は、それをサポートするデータベースでSQL 2003 FILTER WHERE
構文を使用してクエリを生成します。
他のデータベースでは、これはCASE
ステートメントを使用してエミュレートされます。
2つのSQLステートメントは機能的に同等ですが、より明示的なFILTER
の方がパフォーマンスが向上する可能性があります。
条件付きフィルター
条件式がブール値を返す場合、それをフィルターで直接使用することができます。 これは、SELECT
列に追加されないことを意味しますが、結果をフィルタリングするために引き続き使用できます。
SQL用語では、次のように評価されます。