SqlServer 实现oracle10g的wm_concat()函数
2018-01-30 17:27
603 查看
有这么一个表
需求:把id为3所以数据转为1行。以|分隔
1.把id为3的数据转 xml
xml
select '|'+(value) from tb
where id=3
for xml path('')
效果
for xml path('') 括号加东西。的话。类似<li></li>的标签
2. 去掉第一个 | 替换成空格
需要函数 Stuff,, 类似对字符串操作这样的函数还有 replace() right () left() substring() 看需求使用
STUFF 函数将字符串插入另一字符串。它在第一个字符串中从开始位置删除指定长度的字符;然后将第二个字符串插入第一个字符串的开始位置。
Transact-SQL 语法约定
stuff((select '|'+(value) from tb
where id=3
for xml path('')),1,1,'')
这句无法单独运行
3.最终实现
ps:去掉一个where 得到的结果是不一样的,不懂为何。group by id 有去重的效果
注意,如果对应多列进行转行的话,列之间用+号连接的时候,如果列有数字类型的会报将字符串转int失败,那么就需要对int类型的字段加上cast(字段 as varchar(10))
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') insert into tb values(3, 'ddd') insert into tb values(3, 'fff')
需求:把id为3所以数据转为1行。以|分隔
1.把id为3的数据转 xml
xml
select '|'+(value) from tb
where id=3
for xml path('')
效果
for xml path('') 括号加东西。的话。类似<li></li>的标签
2. 去掉第一个 | 替换成空格
需要函数 Stuff,, 类似对字符串操作这样的函数还有 replace() right () left() substring() 看需求使用
STUFF 函数将字符串插入另一字符串。它在第一个字符串中从开始位置删除指定长度的字符;然后将第二个字符串插入第一个字符串的开始位置。
Transact-SQL 语法约定
语法
STUFF ( character_expression , start , length ,character_expression ) |
stuff((select '|'+(value) from tb
where id=3
for xml path('')),1,1,'')
这句无法单独运行
3.最终实现
select id ,value=stuff((select '|'+(value) from tb where id=3 for xml path('')),1,1,'') from tb where id=3 group by id
ps:去掉一个where 得到的结果是不一样的,不懂为何。group by id 有去重的效果
注意,如果对应多列进行转行的话,列之间用+号连接的时候,如果列有数字类型的会报将字符串转int失败,那么就需要对int类型的字段加上cast(字段 as varchar(10))
相关文章推荐
- SqlServer实现oracle10g的 wmsys.wm_concat()/使用自连接、for xml path('')和stuff合并显示多行数据到一行中
- SqlServer实现oracle10g的 wmsys.wm_concat()
- Oracle的行转列的函数wm_concat的db2实现
- Oracle: wmsys.wm_concat、sys_connect_by_path、自定义函数实现行列转换
- Oracle多行转一行:wmsys.wm_concat、sys_connect_by_path、自定义函数实现行列转换
- wm_concat 函数在开发中的应用 (一对多查询数据库实现)
- Oracle: wmsys.wm_concat、sys_connect_by_path、自定义函数实现行列转换
- oracle wm_concat函数简单实例(实现行转成用分隔符分隔的一列)
- wmsys.wm_concat、sys_connect_by_path、自定义函数实现行列转换
- wmsys.wm_concat、sys_connect_by_path、自定义函数实现行列转换
- 存储过程系列二:适用函数wm_concat(column)函数实现字段合并
- wmsys.wm_concat、sys_connect_by_path、自定义函数实现行列转换
- Oracle: wmsys.wm_concat、sys_connect_by_path、自定义函数实现行列转换
- SQL_wm_concat函数实验:实现字段合并
- wmsys.wm_concat、sys_connect_by_path、自定义函数实现行列转换
- wmsys.wm_concat、sys_connect_by_path、自定义函数实现行列转换
- oracle10g中的wm_concat 实现sql查询结果多行转一行
- Oracle List 功能 《=》 Oracle: wmsys.wm_concat、sys_connect_by_path、自定义函数实现行列转换
- wmsys.wm_concat、sys_connect_by_path、自定义函数实现行列转换
- SQL SERVER 合并重复行,行列转换(sql server2000 里面如何实现oracle10g的 wmsys.wm_concat() 的功能?)