私は生産コードで何か気づき、本当に私を捨てました。誰かが私たちと連絡を取った年があるデータテーブルがあります。それは90年代後半に戻ると言います。SQL MAX集計VS.マニュアル計算
私たちには、同じクエリ内の他の将来の計算で使用する前年を計算するクエリがあります。それは次のようになります。
@CurrYear = 2016
select @PrevYear = max(Year)
from x
where x.Year < @CurrYear
これは非常に複雑な方法のように思える...わからないなぜdidntはこの人:
@PrevYear = @CurrYear - 1
私は、クエリのパフォーマンスの観点では、この多くを求めています。どちらが速いの?なぜ前の年を計算するために非常に多くのコードですか?
に依存 – dfundako
作者は、@PrevYear = @CurrYear - 1'を使ったことはありませんでした。作者が正しく、間違って信じていたからです。数年は欠けているかもしれません。 –
クエリはデータ*を持つ前年*を引き出しています。確かに、今年から1を減算することができますが、データが添付されている前年を引っ張ることが意図されていたと思います。データを見ることなく、それは私が言うことができるすべてです。 「どちらが速いの?」 - 1を引く。「正しいですか?」 - わかりません。何が使用されているかによって異なります。 – Siyual