统计连续字段的个数

问题要求
declare @t table(no int)
insert into @t
select 2
union all select 2
union all select 2
union all select 1
union all select 2
union all select 4
union all select 4
union all select 1
union all select 1
想要的答案是 计算出连续的一样no的个数
count_no
3
1
1
2
2

方法:

declare @t table(no int)
insert into @t
select 2
union all select 2
union all select 2
union all select 1
union all select 2
union all select 4
union all select 4
union all select 1
union all select 1

declare @tb table(no1 int)

declare @a varchar(8000),@b int,@c varchar(2)
set @b=1
set @a=”
set @c=”
select @a=@a+’,'+cast(no as varchar(20)) from @t
while(len(@a)>0)
begin
if (@c=”)
begin
set @c=substring(@a,2,1)
set @a=stuff(@a,1,2,”)
end
else
begin
if(@c=substring(@a,2,1))
begin
set @a=stuff(@a,1,2,”)
set @b=@b+1
end
else
begin
set @c=”
insert into @tb select @b
set @b=1
end
end
end
insert into @tb select @b
select * from @tb

no1
———–
3
1
1
2
2

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值