专注于互联网--专注于架构

最新标签
网站地图
文章索引
Rss订阅

首页 »数据库 » 统计字符串长度:分拆统计字符串 »正文

统计字符串长度:分拆统计字符串

来源: 发布时间:星期四, 2009年2月12日 浏览:83次 评论:0


在数据库表tbl1中有个字段Keywords它是nvarchar类型长度为1000该字段内容是所要分析论文关键字
id keywords
-----------------------------------------------------------
1 kw1;kw2;kw3
2 kw2;kw3
3 kw3;kw1;kw4

问题1
对于在keywords字段中出现所有关键字集合(上例中关键字集合为{kw1,kw2,kw3,kw4})中任意个关键字要统计它出现次数(也就是包含该关键字纪录条数)然后写到另张表中最后效果就是
keywords count
-------------------------
kw1 2
kw2 2
kw3 3
kw4 1


问题2
在此基础上要进行组合查询也就是说在整个关键字集合中任意抽出两个关键字统计它们在数据库表纪录中同时出现次数对于上题最后效果要是:
keywords count
----------------------------------
kw1;kw2 1
kw1;kw3 2
kw1;kw4 1
kw2;kw3 2
kw2;kw4 0
kw3;kw4 1


--------------------------------------------------------------------------------------

--统计举例

--为统计处理专门做序数表
select top 1000 id=identity(,1,1) o 序数表 from syscolumns a,syscolumns b
alter table 序数表 add constra pk_id_序数表 primary key(id)
go

--举例数据
create table tbl1(id ,keywords nvarchar(1000))
insert tbl1 select 1,\'kw1;kw2;kw3\'
union all select 2,\'kw2;kw3\'
union all select 3,\'kw3;kw1;kw4\'
go

--第种统计(计数)
select keyword=sub(a.keywords,b.id,charindex(\';\',a.keywords+\';\',b.id)-b.id)
,[count]=count(distinct a.id)
from tbl1 a,序数表 b
where b.id<=len(a.keywords)
and sub(\';\'+a.keywords,b.id,1)=\';\'
group by sub(a.keywords,b.id,charindex(\';\',a.keywords+\';\',b.id)-b.id)
go

--第 2种统计(组合统计)
select keyword=sub(a.keywords,b.id,charindex(\';\',a.keywords+\';\',b.id)-b.id)
,[count]=count(distinct a.id),a.id
o #t
from tbl1 a,序数表 b
where b.id<=len(a.keywords)
and sub(\';\'+a.keywords,b.id,1)=\';\'
group by sub(a.keywords,b.id,charindex(\';\',a.keywords+\';\',b.id)-b.id),a.id

select keyword=a.keyword+\';\'+b.keyword,[count]=sum( a.id when b.id then 1 0 end)
from #t a,#t b
where a.keyword<b.keyword
group by a.keyword,b.keyword
order by keyword

drop table #t
go

--删除测试环境
drop table tbl1,序数表

/*--测试结果

--统计1
keyword count
---------- --------
kw1 2
kw2 2
kw3 3
kw4 1

(所影响行数为 4 行)


--统计2
keyword count
----------------------- -----------
kw1;kw2 1
kw1;kw3 2
kw1;kw4 1
kw2;kw3 2


kw2;kw4 0
kw3;kw4 1

(所影响行数为 6 行)
--*/


0

相关文章

读者评论

发表评论

  • 昵称:
  • 内容: