将记录放入 DataSet中
并按编号排序
然后设置一个编号标志
遍历记录同一标志的组合成一行显示

解决方案 »

  1.   

    交叉表 你在 搜索里找一下 交叉表可以找到很多  可以看看这个例子
    CREATE TABLE [Test] (       [id] [int] IDENTITY (1, 1) NOT NULL ,       [name] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,       [subject] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,       [Source] [numeric](18, 0) NULL ) ON [PRIMARY]GOINSERT INTO [test] ([name],[subject],[Source]) values (N'张三',N'语文',60)INSERT INTO [test] ([name],[subject],[Source]) values (N'李四',N'数学',70)INSERT INTO [test] ([name],[subject],[Source]) values (N'王五',N'英语',80)INSERT INTO [test] ([name],[subject],[Source]) values (N'王五',N'数学',75)INSERT INTO [test] ([name],[subject],[Source]) values (N'王五',N'语文',57)INSERT INTO [test] ([name],[subject],[Source]) values (N'李四',N'语文',80)INSERT INTO [test] ([name],[subject],[Source]) values (N'张三',N'英语',100)Go 
    交叉表语句的实现:--用于:交叉表的列数是确定的select name,sum(case subject when '数学' then source else 0 end) as '数学',          sum(case subject when '英语' then source else 0 end) as '英语',            sum(case subject when '语文' then source else 0 end) as '语文' from test group by name  --用于:交叉表的列数是不确定的declare @sql varchar(8000)set @sql = 'select name,' select @sql = @sql + 'sum(case subject when '''+subject+'''                           then source else 0 end) as '''+subject+''','  from (select distinct subject from test) as a select @sql = left(@sql,len(@sql)-1) + ' from test group by name'exec(@sql)go
      

  2.   

    如果文件的名字是一个固定的集合,比如说就是你列出的4种情况
    并且你用的是存储过程
    可以用sql语句来处理