TSQL。行の多くの列のビットごとの合計を取得する
-
03-07-2019 - |
質問
私は、BITコンセプトで25列の4セットを持つテーブルを持っています。実際にはフィールドはsmallintですが、そのデータでは0または1です。
これは、25 colの最初のグループの合計を取得しようとする私のコードです。
Declare @rows int
, @ID uniqueidentifier
, @LocTotal bigint
select @rows = ( select count(*) from #t1 )
while @rows > 0
begin
print @rows
-- get that rowID
select @ID = (select top 1 recid from #t1)
select @LocTotal =
(select top 1
case when cbHPILoc1 = 1 then 1 else 0 end +
case when cbHPILoc2 = 1 then 2 else 0 end +
case when cbHPILoc3 = 1 then 4 else 0 end +
< snip >
case when cbHPILoc25 = 1 then 16777216 else 0 end
as Total
from dbo.MyTest_BitMap
where RecKey = @ID
)
print @ID
print @LocTotal
私の出力:
(5 row(s) affected)
5
67A16306-B27D-4882-88A2-1146CBAAA8D9
(1 row(s) affected)
4
F94929B9-3DA7-4AA3-96F6-728EF025B21C
合計を @LocTotal
に取得できません
TIA
解決
トマラックがそれを持っていると思うので、私は彼を改造しましたが、これを何度か行うと、すべてが混乱するので:
cbHPILoc1
+ cbHPILoc2 * 2
+ cbHPILoc3 * 4
+ ...
+ cbHPILoc25 * 16777216
退屈でエラーが発生しやすいので、一度ビューとして一度行って、徹底的にテストしてみませんか?
その後、 viewkeyからreckey =?
で合計を選択します。
他のヒント
なぜそんなに複雑なのか
SELECT
RecKey,
cbHPILoc1
+ cbHPILoc2 * 2
+ cbHPILoc3 * 4
+ ...
+ cbHPILoc25 * 16777216
AS Total
FROM
dbo.MyTest_BitMap
WHERE
RecKey = @ID
所属していません StackOverflow