zoukankan      html  css  js  c++  java
  • sql字段合并与分组聚合

    http://blog.csdn.net/cuixianlong/article/details/74024846

    1 字段合并
    原始数据如下:表名为Employee
    ID FirstName LastName Salary
    1 Ming Zhang 8000
    2 Lei Li 16000

    查询SQL:
    SELECT ID, FirstName || ' ' || LastName AS Name, Salary
    FROM Employee

    查询结果:
    ID Name Salary
    1 Ming Zhang 8000
    2 Lei Li 16000
    说明:“||”表示将左右两个字段的内容连接在一起,“AS”表示为这个连接后的字段新命名。

    2 分组聚合
    2.1 字符串聚合
    聚合函数:GROUP_CONCAT(FieldName[, Symbol])
    说明:适用于SQLite,其它数据库暂未测试。

    原始数据如下:表名分别为Employee、Skill、Ely_Skill,表示Employee与Skill的多对多结构,例如:1 Ming Zhang 拥有的技术包括 1 Java、2 C#、3 C++。
    ID First Name Last Name
    1 Ming Zhang
    2 Lei Li

    ID Name
    1 Java
    2 C#
    3 C++

    E_ID S_ID
    1 1
    1 2
    1 3
    2 3
    查询SQL:
    SELECT Employee.*, GROUP_CONCAT(Skill.Name, ',') AS Skills
    FROM Employee
    JOIN Ely_Skill ON Ely_Skill.E_ID = Employee.ID
    JOIN Skill ON Ely_Skill.S_ID = Skill.ID
    GROUP BY Employee.ID

    查询结果:
    ID First Name Last Name Skills
    1 Ming Zhang Java,C#,C++
    2 Lei Li C++

    2.2 数值聚合
    SUM()、COUNT()等常规聚合函数,在网上已有很多完整而详细的介绍,不再赘述。

  • 相关阅读:
    面向对象深入:继承01——子类
    面向对象的基础知识——小结
    IP地址配置
    二、RPM包管理-rpm命令管理
    一、软件包管理简介
    关机重启命令
    网络命令
    权限管理命令
    字符截取命令
    shell-正则表达式(二)
  • 原文地址:https://www.cnblogs.com/liujitao79/p/7741943.html
Copyright © 2011-2022 走看看