很简单的一个SQL语句。

gootey 2011-03-19 11:31:00
有一个t1表:



id name
1 a
2 b
3 c
4 d
5 e
6 f
7 g
8 h



用什么语句可以得到这样的结果:

a.b.c.d.e.f.g.h
...全文
91 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
gootey 2011-03-20
  • 打赏
  • 举报
回复
达人们都睡觉了么?
gootey 2011-03-20
  • 打赏
  • 举报
回复
读出来以后我要在后台使用。
潮起潮落 2011-03-20
  • 打赏
  • 举报
回复
你的意思是说以“a.b.c.d.e.f.g.h”这样的方式读出来在哪里显示?
PitTroll 2011-03-20
  • 打赏
  • 举报
回复
select STUFF((select '.'+name from t1 order by id for xml path('')),1,1,'')
f7812069 2011-03-20
  • 打赏
  • 举报
回复
没错,就是行列转换!
begintransaction 2011-03-20
  • 打赏
  • 举报
回复
行转列,楼上的代码可行。
IHandler 2011-03-20
  • 打赏
  • 举报
回复
或者写个存储过程单独处理,比如游标取值拼接

或者
参考这样

create table test(
id int,
name nvarchar(10)
)
insert into test values(1,'a')
insert into test values(2,'b')
insert into test values(3,'c')


select r from
(select nid,max(a)+'.'+max(b)+'.'+max(c) as r from
(select nid=1,
a=case when name='a' then 'a' else '' end,
b=case when name='b' then 'b' else '' end,
c=case when name='c' then 'c' else '' end
from test)t
group by nid)tt

sxldfang 2011-03-19
  • 打赏
  • 举报
回复
用循环吧,或存储过程。
gootey 2011-03-19
  • 打赏
  • 举报
回复
这么复杂吗
IHandler 2011-03-19
  • 打赏
  • 举报
回复
搜SQL Server 列转行

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧