zoukankan      html  css  js  c++  java
  • SQL Server 表字段值转换成字段名称(二)

    上次写了个比较简单的只有两个字段的例子,经要求在写个  3 个字段的示例 ,贴上来与大家共勉一下   如果你们有更好的方法,提供一下, 感激不尽。

    示例如下:


    /*
    --drop table temp_TestCol_ValueToName;
    -- 创建测试表 (前提 每天每个会员只有一条记录)
    create table temp_TestCol_ValueToName
    (
    userName nvarchar(50), -- 会员名
    myMoney money, -- 金额
    addTime datetime -- 时间
    )
    -- 添加测试数据
    insert into temp_TestCol_ValueToName values('张三',10,'2013-11-01')
    insert into temp_TestCol_ValueToName values('张三',40,'2013-11-02')
    insert into temp_TestCol_ValueToName values('张三',1,'2013-11-03')
    insert into temp_TestCol_ValueToName values('张三',6,'2013-11-04')
    insert into temp_TestCol_ValueToName values('李四',40,'2013-11-02')
    insert into temp_TestCol_ValueToName values('李四',100,'2013-11-03')
    insert into temp_TestCol_ValueToName values('李四',60,'2013-11-06')

    */
    -- 预测查询结果
    -- userName 1 2 3 4 6
    -- 张三 10 40 1 6 0
    -- 李四 0 40 100 0 60

    -- 查询结果
    declare @sql nvarchar(max)='', -- 组装的sql语句
    @month varchar(7)='2013-11'; -- 需要查询的年月(只需要改变这个值)
    select @sql=@sql+ (case @sql when '' then '' else ',' end)
    +'max(case DAY(addTime) when '+CAST(d as varchar)+' then myMoney else 0 end) ['+CAST(d as varchar)+']'
    from (select distinct DAY(addTime) d from temp_TestCol_ValueToName where CONVERT(varchar(7),addTime,120)=@month) a;
    set @sql='select userName [userName],'+@sql+' from temp_TestCol_ValueToName where CONVERT(varchar(7),addTime,120)='''+@month+''' group by userName;';
    exec sp_executesql @sql;

  • 相关阅读:
    window.location.href的使用方法
    hdu 2850 Load Balancing (优先队列 + 贪心)
    几种常见模式识别算法整理和总结
    【DateStructure】 Charnming usages of Map collection in Java
    编写你自己的单点登录(SSO)服务
    微软历史最高市值是多少?
    Tomcat配置一个ip绑定多个域名
    递归算法:求序列的全排列
    SMTP协议分析
    platform_device与platform_driver
  • 原文地址:https://www.cnblogs.com/wbl168/p/SQL_Col_ValueToName.html
Copyright © 2011-2022 走看看