当前位置:首页 > 系统运维 > 正文内容

SQL server合并分拆表的实际应用代码

a8116255316年前 (2010-06-18)系统运维9

以下的文章主要向大家描述的是SQL server合并分拆表的实际操组 *** 的描述,本文是以SQL server合并分拆表的实际操作的应用代码的方式来引出其实际操作步骤,以下就是文章的主要内容描述。

合并分拆表

(Roy)生成測試數據

if not object_id('Tab') is null  drop table Tab  Go  Create table Tab([Col1] int,[Col2] nvarchar(1))  Insert Tab  select 1,N'a' union all  select 1,N'b' union all  select 1,N'c' union all  select 2,N'd' union all  select 2,N'e' union all  select 3,N'f'  Go 

合并表:

SQL2000用函数:

go  if object_id('F_str') is not null  drop function F_Str  go  create function F_Str(@Col1 int)  returns nvarchar(100)  as  begin  declare @S nvarchar(100)  select @S=isnull(@S+',','')+Col2 from Tab where Col1=@Col1  return @S  end  go  Select distinct Col1,Col2=dbo.F_Str(Col1) from Tab  go  

SQL2005用XML:

*** 1:

select   a.Col1,Col2=stuff(b.Col2.value('/R[1]','nvarchar(max)'),1,1,'')  from   (select distinct COl1 from Tab) a  Cross apply  (select COl2=(select N','+Col2 from Tab where Col1=a.COl1 For XML PATH(''), ROOT('R'), TYPE))b 

*** 2:

select   a.Col1,COl2=replace(b.Col2.value('/Tab[1]','nvarchar(max)'),char(44)+char(32),char(44))  from   (select distinct COl1 from Tab) a  cross apply  (select Col2=(select COl2 from Tab where COl1=a.COl1 FOR XML AUTO, TYPE)  .query('<Tab> {for $i in /Tab[position()<last()]/@COl2 return concat(string($i),",")}  {concat("",string(/Tab[last()]/@COl2))}  </Tab>')  )b  SQL05用CTE:  ;with roy as(select Col1,Col2,row=row_number()over(partition by COl1 order by COl1) from Tab)  ,Roy2 as  (select COl1,cast(COl2 as nvarchar(100))COl2,row from Roy where row=1   union all   select a.Col1,cast(b.COl2+','+a.COl2 as nvarchar(100)),a.row from Roy a join Roy2 b on a.COl1=b.COl1 and a.row=b.row+1)  select Col1,Col2 from Roy2 a where row=(select max(row) from roy where Col1=a.COl1) order by Col1 option (MAXRECURSION 0)  

生成结果:

/*  Col1 COl2  ----------- ------------  1 a,b,c  2 d,e  3 f  (3 行受影响)  */   

以上的相关内容就是对SQL server合并分拆表的 *** 的介绍,望你能有所收获。

扫描二维码推送至手机访问。

版权声明:本文由2345好导航站长资讯发布,如需转载请注明出处。

本文链接:http://2345hao.cn/blog/index.php/post/21254.html

分享给朋友:

“SQL server合并分拆表的实际应用代码” 的相关文章

如何设置Win 7通知栏重新显示电源按钮

如何设置Win 7通知栏重新显示电源按钮

有些使用本本的朋友可能会发现,右下角通知栏区域会无法显示电源按钮,导致在插上电源或者是使用电池的时候都无法进行区分。造成这种情况大部分都是因为使用了第三方修改过的系统版本或者对于系统优化过度,所以今天就来解决这个问题。 第一步:在开始菜单的搜索窗口输入“gpedit.msc”,进入组策略编辑器,依...

各个都很实用:windows 7系统电脑日常小技巧

各个都很实用:windows 7系统电脑日常小技巧

在使用Windows 7的时候很多用户对于系统的很多功能并不是很了解,也正是因为这样的不了解导致很多用户在使用Win 之后并不能体验Windows 7的功能便携和强大功能,导致很多用户对于Windows 7的认识还是比较模糊,不过为了让更多的朋友了解Windows 7的特点和便携应用,今天就为大家汇...

微软今天正式停止对windows 7的主流支持

微软今天正式停止对windows 7的主流支持

北京时间1月13日消息,根据计划,微软将于2015年1月13日正式结束对Windows 7SP1的“主流支持”,而这也标志着“扩展支持”阶段的开始,这个阶段将于2020年1月14日结束。 2013年10月份,微软终止销售独立的Windows 7系统安装包,并要求制造商于2014年10月份停止生...

windows7系统下让所有文件夹都使用同一种视图的方法

windows7系统下让所有文件夹都使用同一种视图的方法

Windows 7系统可以对每个文件夹进行个性化视图设置,可以根据自己的个人喜好和实际需要更改文件或文件夹图标的大小,或者让文件或文件夹以列表、平铺等方式显示。但是,假如你对N个文件夹视图进行了风格各异的个性设置,现在又想让所有文件夹都使用同一种视图怎么办呢 手工一个一个修改,你OUT了,非累得手抽...

Ubuntu 14.10上安装新的字体图文教程

Ubuntu 14.10上安装新的字体图文教程

像Ubuntu这种开源系统,一般都自带有好多漂亮的字体,不过假如您想使用您熟悉的字体,可以通过在Ubuntu或其它Linux系统上安装字体,帮助用户在使用开源OS平台上更好的视图体验。 软件名称:Ubuntu 14.04 官方正式版软件大小:752MB更新时间:2014-05-07 Ubun...

windows 7任务栏快捷方式如何居中显示默认从左像右排列

windows 7任务栏快捷方式如何居中显示默认从左像右排列

使用Windows 7的朋友都知道,任务栏上的快捷方式图标都是靠近开始菜单按钮,从左像右排列,不过也有一些用户喜欢左右对称,想要把那些快捷方式居中显示,看起来这个任务好像无从下手,其实一点也不难,只要通过下面方法就能轻松搞定。 1、首先在电脑磁盘中任何一个地方新建一个文件夹。 2、右击任务栏-&...