Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> 查询  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1702114
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

如何实现行列的转换?有关交叉表的应用

作者:cg1  摘自:access911.net  :cg1  更新日期:2005-4-20  浏览人次:

 

我有如下这样一个格式的表:
格式1
列1       列2  
名字1
名字2
          第二列名字1
          第二列名字2 

名字1,名字2 都是有顺序的,是一个名次排列,我如何将第二列的名字1排列到第一列的名字1后面呢?


要加一个名次字段,然后将表格从
格式2
名次      列1       列2  
1         名字1
2         名字2
1                   第二列名字1
2                   第二列名字2 

的格式排列为

格式3
名次      列       名字
1         1        名字1
2         1        名字2
1         2        第二列名字1
2         2        第二列名字2

的表格,然后用交叉表查询向导生成一个交叉表查询,代码如下:

TRANSFORM First(表2.名字) AS 名字之第一条记录
SELECT 表2.名次
FROM 表2
GROUP BY 表2.名次
PIVOT 表2.列;

即可,排列完成后就是以下格式:

格式4
名次      1        2
1         名字1    第二列名字1
2         名字2    第二列名字2

有人提问,如果我直接拿到的就是上述格式4,如何转换为格式3那样呢?
直接用 UNION ALL 就可以实现了
select 名次,"1" as 列,[1] from table union all select 名次,"2" as 列,[2] from table

注意,现在有一些网友用 SUM 加  IIF 函数去实现交叉,access911强烈建议不要这样做,因为这样每条记录都需要去判断,效率极差。当然,同样的原理也适用 SQL SERVER 中用 SUM 加 CASE WHEN 的方法,但是SQL SERVER 稍有不同,因为 SQL SERVER 对此优化比较好,速度不是很慢。


问题:

原数据表
T(字段1)    A(字段2)    B(字段3)    C(字段4)    D(字段5)
1    A1    B1    C1    D1
2    A2    B2    C2    D2
3    A3    B3    C3    D3

新数据表
T(字段1)    M(字段2)    N(字段3)
1    A    A1
1    B    B1
1    C    C1
1    D    D1
2    A    A2
2    B    B2
2    C    C2
2    D    D2
3    A    A3
3    B    B3
3    C    C3
3    D    D3

如何能把第一个表转换成第二个表!?

 

回答:

看最后一句 SQL 代码,就是用 UNION ALL 来转换的

 

本站文章旨在为该问题提供解决思路及关键性代码,并不能完成应该由网友自己完成的所有工作,请网友在仔细看文章并理解思路的基础上举一反三、灵活运用。

access911.net 原创文章,作者本人对文章保留一切权利。
如需转载必须征得作者同意并注明本站链接

 

 
相关文章
     没有手动相关文章
     ADP 中如何实现交叉表查询?
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利