--递归法
create function f_getnum(@i int)
returns @t table(r int)
as
begin
declare @n int
set @n = 1
while 2*@n<=@i
begin
set @n = @n * 2
end
insert @t select @n
set @n = @i - @n
if @n > 0
insert @t select r from f_getnum(@n)
return;
end
go
select * from f_getnum(10)
--循环法
alter function f_getnum (@i int)
returns @t table(r int)
as
begin
declare @n int
while @i > 0
begin
set @n = 1
while 2*@n<=@i
begin
set @n = @n * 2
end
insert @t select @n
set @i = @i - @n
end
return;
end
go
select * from f_getnum(10)
/*
r
-----------
8
2
(2 行受影响)
*/
http://topic.youkuaiyun.com/u/20090807/08/19f980a3-3830-4261-90ca-0f85ec628492.html?72858