sql 方法(长期更新中)

分拆列值

原著:邹建 改编:爱新觉罗.毓华  2007-12-16  广东深圳

有表tb, 如下: id          value ----------- ----------- 1           aa,bb 2           aaa,bbb,ccc 欲按id,分拆value列, 分拆后结果如下: id          value ----------- -------- 1           aa 1           bb 2           aaa 2           bbb 2           ccc

1. 旧的解决方法(sql server 2000) SELECT TOP 8000 id = IDENTITY(int, 1, 1) INTO # FROM syscolumns a, syscolumns b

SELECT A.id, SUBSTRING(A.[values], B.id, CHARINDEX(',', A.[values] + ',', B.id) - B.id) FROM tb A, # B WHERE SUBSTRING(',' + A.[values], B.id, 1) = ','

DROP TABLE #

2. 新的解决方法(sql server 2005)

create table tb(id int,value varchar(30)) insert into tb values(1,'aa,bb') insert into tb values(2,'aaa,bbb,ccc') go SELECT A.id, B.value FROM(     SELECT id, [value] = CONVERT(xml,'<root><v>' + REPLACE([value], ',', '</v><v>') + '</v></root>') FROM tb )A OUTER APPLY(     SELECT value = N.v.value('.', 'varchar(100)') FROM A.[value].nodes('/root/v') N(v) )B

DROP TABLE tb

/* id          value ----------- ------------------------------ 1           aa 1           bb 2           aaa 2           bbb 2           ccc

(5 行受影响) */

 

 

 

表 product

id Pname Pcolor 1  p1    1,2,3 2  p2    2,3 3  p3    1,2,3 4  p4    1,2

现在想得到这么一个结果

colornum  colorId

3  1 4  2 3  3

 

 

create table product (id int,Pname varchar(2),Pcolor varchar(200)) insert into product select 1,'p1','1,2,3' union all select 2,'p2','2,3' union all select 3,'p3','1,2,3' union all select 4,'p4','1,2'

--查询 declare @s varchar(max) set @s='' select @s=@s+Pcolor+',' from product if len(@s)>0 set @s=left(@s,len(@s)-1) select count(*)as colornum ,a as colorId  from f_split(@s,',') group by a order by a

/* ------------------- 3    1 4    2 3    3 */

--送你split函数 create function f_split(@str varchar(8000),@strseprate varchar(1))        returns @temp table(id int identity(1,1),a varchar(100))        as         begin            declare @i int            set @str=rtrim(ltrim(@str))            set @i=charindex(@strseprate,@str)            while @i>=1            begin                insert @temp values(left(@str,@i-1))                set @str=substring(@str,@i+1,len(@str)-@i)      --当然,这里您也可以改写为stuff,可以自己试着改写一下                set @i=charindex(@strseprate,@str)            end            if @str<>'/'               insert @temp values(@str)            return         end

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一直学习

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值