sql 字符串相加
来源:互联网 发布:javascript项目实战pdf 编辑:程序博客网 时间:2024/05/22 04:53
描述:将如下形式的数据按id字段合并value字段。
id value-
---- ------
1 aa
1 bb
2 aaa
2 bbb
2 ccc
需要得到结果:
id value
------ -----------
1 aa,bb
2 aaa,bbb,ccc即:group by id, 求 value 的和(字符串相加)
*/--1、sql2000中只能用自定义的函数解决create table tb(id int, value varchar(10))insert into tb values(1, 'aa')insert into tb values(1, 'bb')insert into tb values(2, 'aaa')insert into tb values(2, 'bbb')insert into tb values(2, 'ccc')gocreate function dbo.f_str(@id varchar(10)) returns varchar(1000)asbegin declare @str varchar(1000) select @str = isnull(@str + ',' , '') + cast(value as varchar) from tb where id = @id return @strendgo--调用函数select id , value = dbo.f_str(id) from tb group by iddrop function dbo.f_strdrop table tb--2、sql2005中的方法create table tb(id int, value varchar(10))insert into tb values(1, 'aa')insert into tb values(1, 'bb')insert into tb values(2, 'aaa')insert into tb values(2, 'bbb')insert into tb values(2, 'ccc')goselect id, [value] = stuff((select ',' + [value] from tb t where id = tb.id for xml path('')) , 1 , 1 , '')from tbgroup by iddrop table tb--3、使用游标合并数据create table tb(id int, value varchar(10))insert into tb values(1, 'aa')insert into tb values(1, 'bb')insert into tb values(2, 'aaa')insert into tb values(2, 'bbb')insert into tb values(2, 'ccc')godeclare @t table(id int,value varchar(100))--定义结果集表变量--定义游标并进行合并处理declare my_cursor cursor local forselect id , value from tbdeclare @id_old int , @id int , @value varchar(10) , @s varchar(100)open my_cursorfetch my_cursor into @id , @valueselect @id_old = @id , @s=''while @@FETCH_STATUS = 0begin if @id = @id_old select @s = @s + ',' + cast(@value as varchar) else begin insert @t values(@id_old , stuff(@s,1,1,'')) select @s = ',' + cast(@value as varchar) , @id_old = @id end fetch my_cursor into @id , @valueENDinsert @t values(@id_old , stuff(@s,1,1,''))close my_cursordeallocate my_cursorselect * from @tdrop table tb
- sql 字符串相加
- 小心SQL中的字符串相加变成NULL
- SQL Server同列字符串相加
- 字符串相加
- 字符串相加
- 字符串相加
- 字符串相加
- 字符串相加
- 某列字符串相加计算的SQL语句的写法
- asp字符串相加
- 关于字符串相加
- 字符串相加的效率
- 长字符串数字相加
- 数据库字符串相加...函数...
- 字符串相加,复制
- CString 字符串相加
- SQLite中将字符串相加
- C++字符串相加
- Linux C函数小总结
- 查看Linux内核版本的命令 .
- iPhone 导航栏标题颜色
- MyEclipse调试
- Android 线程通信
- sql 字符串相加
- 语义网之--RDF概述
- 让你的代码变的更加健壮(Making your C++ code robust)
- CEDET使用
- VC6下Release版工程增加调试信息遇到的问题和解决的方法
- html表格上方的标题怎么相对表格居中
- U-Boot的LDS文件分析
- 说说ARM汇编的LDR伪指令
- 修改CentOS环境变量