SQLServer2008 关于while循环
来源:互联网 发布:网络销售犯罪的特征有 编辑:程序博客网 时间:2024/06/04 18:50
有这样一个表tbl
id code name
11 a aa/bb/cc
22 b ee/rr/tt
需要将name段根据‘/’拆分开来,变成新的数据行
即:
id code name
11 a aa
11 a bb
......以下省略.....
先给该表加上序号,存入临时表
select ROW_NUMBER()OVER(ORDER BY T.code desc) 序号,* into #temp from tbl
--创建一个带有固定列的临时表
create table #temp2
(
ID int,
code varchar(50),
name varchar(50)
)
--使用while循环
declare @name varchar(200)
declare @count int
declare @i int
select @count=COUNT(*) from #temp
set @i=1
while(@i<=@count)
begin
--逐行判断
select @name=t.Name from #temp t where t.序号=@i
while(CHARINDEX('/',@name,1)!=0)
begin
insert into #temp2 select t.id,t.code,SUBSTRING(@name,1,CHARINDEX('/',@name,1)-1) from #temp t where t.序号=@i
set @name3=SUBSTRING(@name,CHARINDEX('/',@name,1)+1,LEN(@name)-len(SUBSTRING(@name,1,CHARINDEX('/',@name,1))))
end
if(CHARINDEX('/',@name,1)=0)
begin
insert into #temp2 select t.id,t.code,@name from #temp t where t.序号=@i
end
set @i=@i+1
end
select * from #temp2
注意:
insert into #temp from XX 只能往已经存在的表里插入值
select * into #temp 可以往未创建的表里添加值
- SQLServer2008 关于while循环
- 关于while循环
- 关于while循环
- 关于for循环,while循环
- 关于while循环中的~scanf()
- java中关于循环那点事(while循环,do-while循环,for循环)
- 关于do while循环的问题
- 关于do while循环的问题
- 关于for循环和while循环中的次数问题
- while循环
- while循环
- while循环
- while循环
- while循环
- While循环
- while循环
- while 循环
- while循环
- windows 装XP系统
- Foeach 时修改集合的值报错
- linuxrw
- 亲爱的程序猿们怎么找工作
- SQLServer2008 表连接时null 和 null 无法匹配?
- SQLServer2008 关于while循环
- 第5周项目1-(2)
- Aspose.Cells 使用汇总
- [转]IOS开源项目组件
- JAVA多线程和并发基础面试问答
- [转]接口和抽象类
- Windows7添加路径到path环境变量
- Java中Ajaxa中文乱码问题
- 项目2——游戏中的角色类