`
lyongde
  • 浏览: 90783 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

求解,关于sql字符串拆分并统计的问题。

阅读更多
急,望各位给出解答------

数据表如下:

字段:    地点                       人数
-------------------------------------------
数据:    上海,北京                   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
分享到:
评论
1 楼 hama 2008-06-11  
数据: 北京,南京,西安 500

这条说的是,北京、南京、西安各500,还是总共500?

相关推荐

Global site tag (gtag.js) - Google Analytics