sql server 列转行

来源:未知 责任编辑:责任编辑 发表时间:2013-08-27 11:18 点击:
两个表
 
表1:tb_Site
 
 
 
 
CREATE TABLE [dbo].[tb_Site] ( 
    [sid] [int] IDENTITY (1, 1) NOT NULL , 
    [sname] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL  
) ON [PRIMARY] 
GO 
 
 
 
 
表2:tb_qx
 
 
 
 
CREATE TABLE [dbo].[tb_qx] ( 
    [qid] [int] IDENTITY (1, 1) NOT NULL , 
    [qname] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL  
) ON [PRIMARY] 
GO 
 
 
动态SQL
 
 \
 
 
 
 
declare @sql1 varchar(8000) 
set @sql1='select c.sname ' 
select @sql1=@sql1+', max(case qname when'''+qname+'''then qname else ''0'' end) ['+qname+']' from tb_qx  
select @sql1=@sql1+' from (select * from tb_Site left join (select * from tb_qx) d on 1=1) c group by c.sname' 
exec(@sql1) 
 \
 
摘自 李晓光的专栏
    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>

    推荐热点

    • sql常见面试题
    • SQL SERVER 2005性能之跟踪
    • SQL编程(一)
    • LINUX上RMAN自动备份脚本
    • sql server面试题
    • 如何将多个SQL查询统计结果一次显示出来
    • 浅谈SQL Server中的事务日志(三)----在简单恢复模式下日志的角色
    • sql server 列转行
    • SQL小技巧系列 --- 行转列合并
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1