zoukankan      html  css  js  c++  java
  • 解决一条特殊的分类统计问题(SQL)

    原问题如下:
    /*
    table1:
    序号   类别
    01     玩具
    02     食物
    table2:
    序号   类别    名称    对应编号
    01     玩具    大小      A1
    02     玩具    面积      A2
    03     玩具    体积      A3
    04     食物    重量      A7
    05     食物    颜色      A9
    table3:
    序号   物品   A1    A2    A3   A4   A5   A6    A7   A8   A9   A10 ..
    01     皮球   10    20    30
    02     篮球   20    30    40
    03     苹果                                    20        50
    04     香蕉                                    80        70

    显示效果
    对应2种类别
    当是玩具类别时候显示
    物品   类别   大小   面积   体积
    皮球   玩具   10      20     30
    篮球   玩具   20      30     40
    当是食物类别时候显示
    物品   类别   重量   颜色
    苹果   食物   20      50
    香蕉   食物   80      70

    请给出具体的查询过程。。谢谢

    */

    自感觉不错的一个解决方法:
    create table A(序号 nvarchar(10),类别 nvarchar(10))
    insert A select  '01',     '玩具'
    union all select '02',     '食物'

    create table B(序号 nvarchar(10), 类别 nvarchar(10), 名称 nvarchar(10), 对应编号 nvarchar(10))
    insert B select '01',     '玩具',    '大小',      'A1'
    union all select '02',     '玩具',    '面积',      'A2'
    union all select '03',     '玩具',    '体积',      'A3'
    union all select '04',     '食物',    '重量',      'A7'
    union all select '05',     '食物',    '颜色',      'A9'
    create table C(序号 nvarchar(10), 物品 nvarchar(10), A1 int, A2 int, A3 int, A4 int, A5 int, A6 int, A7 int, A8 int, A9 int, A10 int)
    insert C(序号, 物品, A1, A2, A3) values('01','皮球',10,20,30)
    insert C(序号, 物品, A1, A2, A3) values('02','篮球',20,30,40)
    insert C(序号, 物品, A7, A9) values('03','苹果',20,50)
    insert C(序号, 物品, A7, A9) values('04','香蕉',80,70)


    DECLARE @Input nvarchar(10--要统计的类别,可以根据实际需要输入
    DECLARE @EXECUTE_SQL nvarchar(4000)
    DECLARE @EXECUTE_WHERE nvarchar(4000)

    SELECT @Input='食物',@EXECUTE_SQL='SELECT [物品],'''+@Input +''' AS [类别]',@EXECUTE_WHERE=' WHERE 1=1'

    SELECT @EXECUTE_SQL=@EXECUTE_SQL+',SUM('+[对应编号]+') AS ['+[名称]+']'
            ,
    @EXECUTE_WHERE=@EXECUTE_WHERE+' AND '+[对应编号]+' IS NOT NULL' 
        
    FROM B WHERE B.[类别]=@Input
    SET  @EXECUTE_SQL=@EXECUTE_SQL+' FROM C '+@EXECUTE_WHERE+' GROUP BY [物品] '
    EXECUTE(  @EXECUTE_SQL)
    DROP TABLE A,B,C
    /*
    物品   类别   大小   面积   体积
    皮球   玩具   10      20     30
    篮球   玩具   20      30     40

    当是食物类别时候显示
    物品   类别   重量   颜色
    苹果   食物   20      50
    香蕉   食物   80      70
    */
    不是很难,要说难点就是怎么样构造SQL语句而已。
    原帖:http://community.csdn.net/Expert/topic/5535/5535330.xml?temp=.8875543
  • 相关阅读:
    golang 简易聊天
    golang 自定义封包协议(转的)
    PHP 7 测试用例(转)
    android 百度地图开发
    Android studio 签名使用转
    百度ueditor 拖文件或world 里面复制粘贴图片到编辑中 上传到第三方问题
    Android控件属性大全(转)
    Android studio 一个项目中添加两个module遇到的bug
    win7 64位DCOM配置(关于导出excel 配置计算机组件服务)(转)
    Python学习--07迭代器、生成器
  • 原文地址:https://www.cnblogs.com/wghao/p/748964.html
Copyright © 2011-2022 走看看