本文目录
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()等常规聚合函数,在网上已有很多完整而详细的介绍,不再赘述。
1257

被折叠的 条评论
为什么被折叠?



