• 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;

  • 相关阅读:
    web常用自动化库——selenium总结(转)
    前端框架面试题
    SpringBoot整合Knife4j展示更美观的API文档
    JUC- ThreadLocal学习笔记
    JUC-ThreadPool线程池的使用与学习
    Java8 新特性
    SpringBoot 整合FreeMarker进行邮件发送
    IDEA 打开别人的项目的是Maevn插件依赖出错问题处理
    Liunx常用指令备查
    第四次作业
  • 原文地址:https://www.cnblogs.com/wbl168/p/SQL_Col_ValueToName.html
Copyright © 2020-2023  润新知