0
私はプロジェクトに取り組んでおり、Django Sum()
注釈が外部キーとフィールドの合計を作るときに正しく動作していないことに気付きました。Django Sum Annotation with Foreign keys
たとえば、誰かが注文できるウェブサイトにアクセスしたとき。 Order
モデルにはVisit
モデルへのリンクがあります。これは、1回の訪問で複数の注文を行うことができるためです。しかし、ウェブサイトから来ていない注文にはウェブサイトの訪問はありません。これらの注文については、訪問はNULL
になります。次のようにすると、計算が正しく行われません(値が大きすぎます)。
visits = visits.annotate(order_total = Sum('order__total'))
私はAvg
にSum
を変更すると、計算が正しく行われています。これについて論理的な説明はありますか?
あなたのデータの例を表示してください。 –
私はちょっと高い値が元の数の倍数であることを知りました。私はこれが別個の価値と関係していると思いますか?例:3978.30は51717.90(x13)になり、189.90は3418.20(x18)になります。 – user2621686
@ user2621686元の「訪問数」クエリはどのように見えますか? –