科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道适合SQL初学者学习的SQL FAQ集锦(1)

适合SQL初学者学习的SQL FAQ集锦(1)

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

假设有张学生成绩表(CJ)如下

作者:li 来源:赛迪网 2007年8月26日

关键字: 集锦 数据库 SQL Server SQL Server 各版本

  • 评论
  • 分享微博
  • 分享邮件
 

1. 行列转换--普通

  

假设有张学生成绩表(CJ)如下:

Name  Subject   Result
张三  语文    80
张三  数学    90
张三  物理    85
李四  语文    85
 
李四  数学    92
李四  物理    82
  
想变成

姓名  语文  数学  物理
张三  80   90   85
李四  85   92   82

  

declare @sql varchar(4000)
set @sql = 'select Name'
select @sql = @sql + ',sum(case Subject when '''+Subject+''' 
then Result end) ['+Subject+']'
from (select distinct Subject from CJ) as a
select @sql = @sql+' from test group by name'
exec(@sql)

2. 行列转换--合并

有表A,
 id pid
 1   1
 1   2
 1   3
 2   1
 2   2
 3   1
如何化成表B:
 id pid
  1  1,2,3
  2  1,2
  3  1

创建一个合并的函数

create function fmerg(@id int)
returns varchar(8000)
as
begin
declare @str varchar(8000)
set @str='
select @str=@str+','+cast(pid as varchar) from 表A where id=@id
set @str=right(@str,len(@str)-1)
return(@str)
End
go

--调用自定义函数得到结果

select distinct id,dbo.fmerg(id) from 表A
    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章