涛子 - 简单就是美

成单纯魁增,永继振国兴,克复宗清政,广开家必升

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
  428 随笔 :: 0 文章 :: 19 评论 :: 22万 阅读

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

posted on   北京涛子  阅读(1221)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· AI与.NET技术实操系列(六):基于图像分类模型对图像进行分类
点击右上角即可分享
微信分享提示