ホームページ >データベース >mysql チュートリアル >SQLで起算日に基づいてトランザクションIDごとに現金価値を効率的に合計する方法は?

SQLで起算日に基づいてトランザクションIDごとに現金価値を効率的に合計する方法は?

Linda Hamilton
Linda Hamiltonオリジナル
2024-12-16 11:14:10519ブラウズ

How to Efficiently Sum Cash Values by Transaction ID Based on Value Date in SQL?

条件付き値の日付を使用した合計の計算

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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。