多列转1列SqlServer实现oracle10g的wmsys.wm
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了多列转1列SqlServer实现oracle10g的wmsys.wm,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1510字,纯文字阅读大概需要3分钟。
内容图文
![多列转1列SqlServer实现oracle10g的wmsys.wm](/upload/InfoBanner/zyjiaocheng/533/398ec68cbb6d4c1c8ab6d882d1ff11db.jpg)
有这么一个表 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 , '
有这么一个表
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('')
效果
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 有去重的效果
效果图。没有------------
在oracle 数据库中他也有自己的实现。觉得这些东西没有什么的。只要你有需求,必然有答案,只是你接触了没有而已。反正现在编程我们都是站在巨人的肩膀上了。
内容总结
以上是互联网集市为您收集整理的多列转1列SqlServer实现oracle10g的wmsys.wm全部内容,希望文章能够帮你解决多列转1列SqlServer实现oracle10g的wmsys.wm所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。