ホームページ >データベース >mysql チュートリアル >SQLで起算日に基づいてトランザクションIDごとに現金価値を効率的に合計する方法は?
条件付き値の日付を使用した合計の計算
SQL ステートメントで、最後のトランザクション内の一意のトランザクション ID ごとに合計現金を計算したいとします。月。これを実現するには、既存のステートメントを変更して、特定の日付以降の起算日を持つ現金価値のみを含めるという条件を含める必要があります。
これに対処するために、CASE ステートメントを使用しようとしましたが、構文が正しくないため、エラーが発生しました。
検索された CASE 式の正しい構文は次のとおりです:
CASE WHEN Boolean_expression THEN result_expression [ ...n ] [ ELSE else_result_expression ] END
式を変更する必要があります次のように:
SUM(CASE WHEN ValueDate > @startMonthDate THEN cash ELSE 0 END)
この式は、各レコードの ValueDate フィールドを評価します。 ValueDate が指定された開始月日より大きい場合は、現金価値が返されます。それ以外の場合は 0 が返されます。結果の値が合計されて、指定された期間の合計現金が得られます。
代替アプローチ
パフォーマンスを向上させるには、代わりに JOIN および GROUP BY ステートメントを使用することを検討してください。依存サブクエリ:
SELECT SUM(cash) FROM Table_a AS a JOIN Table_b AS b ON a.branch = b.branch AND a.transID = b.transID WHERE ValueDate > @startMonthDate GROUP BY a.transID
このアプローチでは、サブクエリに関連するオーバーヘッドが回避され、次のような結果が生じる可能性があります。実行時間が短縮されます。
以上がSQLで起算日に基づいてトランザクションIDごとに現金価値を効率的に合計する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。