% モードで結果を取得する SQL クエリを作成する際に問題に直面しています。SQL ServerSUM()
のCOUNT()
機能に慣れていますが、クエリ内にロジックを実装する際に問題に直面しています。
UserName--- % of AccepectResult---- % of RejectResult
私のテーブル構造は次のようなもので、2 つの列Name
(UserName) とResult
:
NAME Result
---------------
USer1 A
USer1 A
USer1 A
USer1 R
USer1 R
USer1 A
USer2 A
USer2 A
USer2 A
USer2 A
USer2 R
A - Accepted Result
R - Rejected Result
このクエリを次のように記述しようとしています..
select * into #t1 from
(
select UserName , count(Result) as Acc
from Test where result = 'A'
group by UserName
) as tab1
select * into #t2 from
(
select UserName , count(Result) as Rej
from Test where result = 'R'
group by UserName
) as tab2
select #t1.UserName ,
#t1.Acc ,
#t2.Rej ,
(#t1.Acc)*100/(#t1.Acc + #t2.Rej) as AccPercentage,
(#t2.Rej)*100/(#t1.Acc + #t2.Rej) as RejPercentage
from #t1
inner join #t2 on #t1.UserName = #t2.UserName
drop table #t1
drop table #t2
このクエリと、SQL Server でパーセンテージを計算するための組み込み関数を記述する他の方法はありますか?