duanlushen8940 2012-12-29 12:42
浏览 46
已采纳

查询和回声解决方案? [关闭]

Having a hard time trying to work out how to make a mysql query and output the data into a table like the one I have made below.

Been playing around for a few days now with no luck, so any help would be much appreciated.

The image below shows my 3 database tables(in simple form) and what i'm trying to output using PHP/MYSQL.

The image also shows the total amount (count) of listings for each user for each category, I cant work out how i join it all together.

Hope this makes some sense!

http://img.photobucket.com/albums/v432/Winegums/table_zps2b57f483.jpg

  • 写回答

1条回答 默认 最新

  • duanci3845 2012-12-29 12:46
    关注

    Initially, you can do it like this,

    SELECT  a.user_name,
            SUM(CASE WHEN c.cat_name = 'books' THEN 1 ELSE 0 END) books,
            SUM(CASE WHEN c.cat_name = 'videos' THEN 1 ELSE 0 END) videos
    FROM    users a 
            LEFT JOIN downlods b
                ON a.user_ID = b.user_ID
            LEFT JOIN download_cats c
                ON b.cat_id = c.cat_id
    GROUP BY a.user_name
    

    But I guess you have unknown number of cat_name on your table. A Dynamic SQL is much more preferred,

    SET @sql = NULL;
    SELECT
      GROUP_CONCAT(DISTINCT
        CONCAT(
          'SUM(CASE WHEN c.cat_name = ''',
          cat_name,
          ''' THEN 1 ELSE 0 END) AS ',
          cat_name
        )
      ) INTO @sql
    FROM download_cats;
    
    SET @sql = CONCAT(' SELECT  a.user_name, ', @sql, ' 
                        FROM    users a 
                                LEFT JOIN downlods b
                                    ON a.user_ID = b.user_ID
                                LEFT JOIN download_cats c
                                    ON b.cat_id = c.cat_id
                        GROUP BY a.user_name');
    
    PREPARE stmt FROM @sql;
    EXECUTE stmt;
    DEALLOCATE PREPARE stmt;
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 远程桌面文档内容复制粘贴,格式会变化
  • ¥15 关于#java#的问题:找一份能快速看完mooc视频的代码
  • ¥15 这种微信登录授权 谁可以做啊
  • ¥15 请问我该如何添加自己的数据去运行蚁群算法代码
  • ¥20 用HslCommunication 连接欧姆龙 plc有时会连接失败。报异常为“未知错误”
  • ¥15 网络设备配置与管理这个该怎么弄
  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题