У меня есть таблица под
numbers
794
709090
, что мне нужно, это сумма всех цифр, таких как 7 + 9 + 4 = 20;2 + 0 = 2 или 7 + 0 + 9 + 0 + 9 + 0 = 25;2 + 5 = 7 .
Я пытался с помощью приведенного ниже сценария, но почему-то не работает:
declare @t table(numbers int)
insert into @t select 794 union all select 709090
declare @maxValue int
select @maxValue = max(numbers) from @t
;with cte as(
SELECT SUM(CAST(SUBSTRING(cast(numbers as varchar(1000)),number,1) AS INT)) SUMOFDIGITS FROM @t
cross apply (
SELECT DISTINCT number FROM
MASTER..SPT_VALUES WHERE number > 0 AND number <= DATALENGTH(@maxValue) ) x)
select SUMOFDIGITS, finalsum = cast(left(SUMOFDIGITS,1) as int)+cast(right(SUMOFDIGITS,1) as int)
from cte