• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    数据库实现行列转换(mysql示例)

    这篇文章通过sql示例代码给大家介绍了mysql数据库如何实现行列转换,下面话不多说,直接来看示例代码吧。

    原表:

    表名 :user
    ----------------------------------------
    name    | course  | grade
    ----------------------------------------
    zhangsan  | Java   | 70
    ----------------------------------------
    zhangsan  | C++   | 80
    ----------------------------------------
    lisi    | java   | 90
    ----------------------------------------
    lisi    | C#    | 60
    ----------------------------------------

    用一条 SQL 语句得到如下形式:

    ----------------------------------------
    name   | java | C++ | C#
    ----------------------------------------
    zhangsan | 70  | 80  | null
    ----------------------------------------
    lisi   | 90  | null | 60
    ----------------------------------------

    方案一

    select  name,
    sum(case when course='java' then grade end) as java,
    sum(case when course='C++' then grade end) as C++,
    sum(case when course='C#' then grade end) as C#
    from test group by name

    方案二

    select distinct c.`name` AS name,
    (select grade from test where name = c.`name` and course = 'java' )as java,
    (select grade from test where name = c.`name` and course = 'C++' )as C++,
    (select grade from test where name = c.`name` and course = 'C#' )as C#
    from test c

    总结

    以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能有一定的帮助,如果有疑问大家可以留言交流。

    您可能感兴趣的文章:
    • mysql 行列动态转换的实现(列联表,交叉表)
    • mysql 行列转换的示例代码
    上一篇:Linux系统下mysqlcheck修复数据库命令(详解)
    下一篇:MySQL无法重启报错Warning: World-writable config file ‘/etc/my.cnf’ is ignored的解决方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    数据库实现行列转换(mysql示例) 数据库,实现,行列,转换,