浏览 1562 次
锁定老帖子 主题:求解,关于sql字符串拆分并统计的问题。
该帖已经被评为隐藏帖
|
|
---|---|
作者 | 正文 |
发表时间:2008-06-11
数据表如下: 字段: 地点 人数 ------------------------------------------- 数据: 上海,北京 130 数据: 北京,南京,西安 500 数据: 西安 60 ------------------------------------------ 现想分别统计出 各地点 的人数总和,比如: 北京630人,西安560人等,如果[地点]字段有多个城市,每个城市人数分别有[人数]。如何写sql。 我有一个函数,只能拆分一个字符串。 ------------------------------------------------------- --SQL中字符串拆分通用函数 CREATE FUNCTION uf_StrSplit (@origStr varchar(7000), --待拆分的字符串 @markStr varchar(100)) --拆分标记,如',' RETURNS @splittable table ( str_id varchar(4000) NOT NULL, --编号ID string varchar(2000) NOT NULL --拆分后的字符串 ) AS BEGIN declare @strlen int,@postion int,@start int,@sublen int,@TEMPstr varchar(200),@TEMPid int SELECT @strlen=LEN(@origStr),@start=1,@sublen=0,@postion=1,@TEMPstr='',@TEMPid=0 if(RIGHT(@origStr,1)<>@markStr ) begin set @origStr = @origStr + @markStr end WHILE((@postion<=@strlen) and (@postion !=0)) BEGIN IF(CHARINDEX(@markStr,@origStr,@postion)!=0) BEGIN SET @sublen=CHARINDEX(@markStr,@origStr,@postion)-@postion; END ELSE BEGIN SET @sublen=@strlen-@postion+1; END IF(@postion<=@strlen) BEGIN SET @TEMPid=@TEMPid+1; SET @TEMPstr=SUBSTRING(@origStr,@postion,@sublen); INSERT INTO @splittable(str_id,string) values(@TEMPid,@TEMPstr) IF(CHARINDEX(@markStr,@origStr,@postion)!=0) BEGIN SET @postion=CHARINDEX(@markStr,@origStr,@postion)+1 END ELSE BEGIN SET @postion=@postion+1 END END END RETURN END 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2008-06-11
数据: 北京,南京,西安 500
这条说的是,北京、南京、西安各500,还是总共500? |
|
返回顶楼 | |