0 0

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

望各位大虾们解答,急中......
数据表如下:

字段:    地点                       人数
-------------------------------------------
数据:    上海,北京                   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
2008年6月11日 09:24

3个答案 按时间排序 按投票排序

0 0

提供个思路,test为你说的那个数据表,tt表结构与test一样,过来存储分离后的数据。如果你想直接出结果,自己再改改吧
例如:test
字段: 地点 人数
-------------------------------------------
数据: 上海,北京 130
数据: 北京,南京,西安 500
数据: 西安 60
tt
字段: 地点 人数
-------------------------------------------
数据: 上海 130
数据: 北京 130
数据: 北京 500
数据: 南京 500
数据: 西安 500
数据: 西安 60

DECLARE 
t test%ROWTYPE;
name test.name%TYPE;
CURSOR c IS SELECT name,num FROM test; 
BEGIN 
OPEN c; 
  LOOP 
    FETCH c INTO t; 
    EXIT WHEN c%NOTFOUND; 
    name := t.name;
    WHILE INSTR(name,',')>0 LOOP
        insert into tt values (SUBSTR(name,1,INSTR(name,',')-1),t.num);
        name := SUBSTR(name,INSTR(name,',')+1,LENGTH(name)-INSTR(name,','));
    END LOOP;
    insert into tt values (name,t.num);
  END LOOP;
CLOSE c;
END; 

2008年6月12日 09:44
0 0

引用
字段: 地点 人数
-------------------------------------------
数据: 上海,北京 130
数据: 北京,南京,西安 500
数据: 西安 60
------------------------------------------

数据库是这样设计的吗,设计都是错的,你还做什么做,到头来就是一滩烂泥

2008年6月11日 16:35
0 0

我觉得你在程序里得到结果好一些

2008年6月11日 10:15

相关推荐

    字符串问题详解

    字符串问题在计算科学中占有重要的地位,涉及字符处理的各种算法和数据结构。常见的字符串处理包括查找、替换、连接、插入和删除等基本操作,而更深入的算法如最长公共子序列(LCS)和最长公共子串(LIS)则是研究字符串...

    计算字符串中最大回文长度,并返回回文字符串及长度

    这个问题是字符串处理和算法设计的经典问题,涉及到的主要知识点包括字符串操作、动态规划和回文子串搜索。 首先,我们需要理解如何定义一个回文字符串。一个字符串s是回文的,如果从左到右读和从右到左读是一样的...

    C语言求解最长公共子字符串问题及相关的算法分析

    最长公共子字符串问题是一个经典计算机科学问题,主要目标是找到两个字符串中连续出现的最长相同字符序列。在C语言中,这个问题通常通过动态规划方法来解决。动态规划是一种解决复杂问题的有效策略,它通过将问题...

    5统计某个字符串中大小写字母A或a出现的次数java

    标签"统计"、"字符串"、"字母"、"出现的次数"表明这是关于字符串处理和字符计数的编程问题。通过学习这个例子,你可以了解到Java中的字符串操作、字符遍历以及条件判断等基础知识。 总结一下,统计字符串中特定字符...

    动态规划算法求解字符串比较问题c++源代码

    对于给定的字符串A和B,给定其字串的内容和空格相对字符的距离,使用动态规划算法求解两字符串的扩展距离。

    ACM之字符串模板

    KMP 算法和拓展 KMP 算法是其中两个最重要的组成部分,它们可以帮助我们快速解决字符串匹配、子串出现次数统计等问题。 因此,在 ACM 竞赛中,掌握字符串类型数据结构模板非常重要,可以帮助选手提高比赛的成绩。

    Manacher算法:求解最长回文字符串,时间复杂度为O(N)

    Manacher算法:求解最长回文字符串,时间复杂度为O(N) 回文串定义:“回文串”是一个正读和反读都一样的字符串,比如“level”或者“noon”等等就是回文串。回文子串,顾名思义,即字符串中满足回文性质的子串。

    C语言编程-编写一个函数,该函数可以统计一个长度为2的字符串在另一个字符串中出现的次数;

    C语言编程-编写一个函数,该函数可以统计一个长度为2的字符串在另一个字符串中出现的次数;

    C语言中关于字符串左右循环移位的问题

    C语言中关于字符串左右循环移位的问题是一个经典的编程题型,今天我们将对其进行详解,并给出两种方法求解。 首先,让我们来解决字符串循环右移的问题。方法一:利用已有的字符串函数。我们可以使用strcpy函数和...

    求解两种排序方法问题.cpp

    考拉有n个字符串字符串,任意两个字符串长度都是不同的。考拉最近学习到有两种字符串的排序方法: 1.根据字符串的字典序排序。例如: “car” “carriage” “cats” “koala” 2.根据字符串的长度排序。例如: ...

    C++求解合并字符串最小成本

    C++求解合并字符串最小成本 给定n个字符串的长度,求合并成一个字符串产生的最小成本。

    动态规划求字符串比较问题

    《动态规划》之--字符串比较问题(扩展距离),主要思路通过策略和无效性来求解。特点最优子结构性质,重叠子问题。

    字符串排列问题,不含重复

    本问题的核心是求解一个字符串中不重复字符的所有可能排列,并计算这些排列的总数。这个问题可以使用C++这样的编程语言来解决,因为它提供了丰富的数据结构和算法库。 首先,我们需要理解题目给出的要求。当输入一...

    excel规划求解,sql实现方法,在m个数据中找出合计值等于特定值的n个数据,亲测可用,速度超快,比excel快N倍

    excel规划求解sql实现方法,在m个数据中找出合计值等于特定值的n个数据,执行效率远远大于excel的效率,在excel几个小时无法求解但在ORACLE数据库(其他数据库同样可以)秒级执行完毕。适用多种数据库

    数字字符串求解三方法

    ### 数字字符串求解三方法 #### 概述 在计算机编程中,处理字符串是非常常见的需求之一,尤其是在涉及数值计算的场景下。对于数字字符串的处理,常常需要判断一个字符串是否能够表示一个合法的数值。本文将介绍三...

    高等应用数学问题的MATLAB求解 第9章 概率论与数理统计问题的计算机求解 共104页.pptx

    【课程大纲】 第1章 计算机数学语言描述 共33页.pptx 第2章 MATLAB语言程序设计基础 共61页.pptx ...第9章 概率论与数理统计问题的计算机求解 共104页.pptx 第10章 数学问题的非传统解法 共147页.pptx

    列出字符串的全部排列组合

    从给定的代码片段来看,该程序旨在生成一个字符串的所有可能排列组合,但代码实现上存在一些问题,例如,函数命名、逻辑结构以及对内存管理的处理方式等,都偏离了标准的C语言编程实践。下面,我们将深入解析标题、...

    字符串中的最长重复串

    Manacher的算法是一种优化后的动态规划方法,专门针对寻找字符串中的最长回文子串,但在适当修改后,也可以用于求解最长重复子串。它利用了字符串的对称性,减少了重复计算,提高了效率。 无论采用哪种方法,都...

    使用swap函数求解带有重复字符串的全排列

    换种思维,对122,第一个数1与第二个数2交换得到212,然后考虑第一个数1与第三个数2交换,此时由于第三个数等于第二个数,所以第一个数不再与第三个数交换。再考虑212,它的第二个数与第三个数交换可以得到解决221。...

Global site tag (gtag.js) - Google Analytics