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;

  • 相关阅读:
    汇编语言LAHF和SAHF指令
    JSONHelper
    【CSS】利用宽高比例的媒体查询
    swiftmailer时没有设置https的选项,才可以发送成功。在linux下面
    DevExpress
    IntelliJ IDEA2017 激活方法 最新的激活注册方式方法,破解,密钥
    vue.js 列表追加项写法
    RedisCache 缓存
    时间通用类 datetime
    LogHelper 日志
  • 原文地址:https://www.cnblogs.com/wbl168/p/SQL_Col_ValueToName.html
Copyright © 2011-2022 走看看