初入Sql Server 之聚合函数以及多表联合查询
一、简介
在SQL中,聚合函数用于一组数据的处理,所以常常会与SELECT 和GROUP BY 一起使用,比如查询每个学生成绩表中的总分、平均分等等,都需要使用到聚合函数
二、聚合函数的使用
2.1 SUM() 求和函数
假设在表table_score中有字段 col_id,col_student_id,col_datetime,col_score 求出每个col_student_id的总分
SELECT SUN(col_score) '总分' FROM table_score GROUP BY col_student_id
也可求出col_student_id = 2 的总分
SELECT SUN(col_score) '总分' FROM table_score WHERE col_student_id = 2
还可以使用HAVING 过滤掉编号大的数据
SELECT SUN(col_score) '总分' FROM table_score GROUP BY col_student_id HAVING col_student_id >3
2.2 AVG() 求平均值函数
SELECT AVG(col_score) '平均分' FROM table_score GROUP BY col_student_id SELECT AVG(col_score) '平均分' FROM table_score WHERE col_student_id = 2 SELECT AVG(col_score) '平均分' FROM table_score GROUP BY col_student_id HAVING col_student_id > 3
2.3 MAX()最大值函数
SELECT MAX(col_score) '最高分' FROM table_score GROUP BY col_student_id SELECT MAX(col_score) '最高分' FROM table_score WHERE col_student_id = 2 SELECT MAX(col_score) '最高分' FROM table_score GROUP BY col_student_id HAVING col_student_id > 3
2.4 MIN()最小值
SELECT MIN(col_score) '最低分' FROM table_score GROUP BY col_student_id SELECT MIN(col_score) '最低分' FROM table_score WHERE col_student_id = 2 SELECT MIN(col_score) '最低分' FROM table_score GROUP BY col_student_id HAVING col_student_id > 3
2.5 COUNT()
COUNT() 常常用来求数量,我一般喜欢使用COUNT(*)来计算符合条件的数量,比如求每个学生的考试科目数
SELECT COUNT(*) '数量' FROM table_score GROUP BY col_student_id
三、联合查询
假设有表table_name1,table_name2 ,表table_name1中的主键tid为表table_name2的外键
1.比较简易的多表连接写法,只能查到两个表中都有的数据,与inner join查询一致
SELECT t1.col1, t1.col2, t2.col1, t2.col2 FROM table_name1 AS t1, table_name2 AS t2 WHERE t1.tid = t2.tid
2.左外联
left outer join 以左边的表为准,只要左边的表中有数据,都会显示出来,若对应右边的表没有数据,就会全部显示为NULL值
SELECT t1.col1, t1.col2, t2.col1, t2.col2 FROM table_name1 AS t1, table_name2 AS t2 LEFT OUTER JOIN t1.tid = t2.tid
3.右外联
right outer join 与左外联相反
SELECT t1.col1, t1.col2, t2.col1, t2.col2 FROM table_name1 AS t1, table_name2 AS t2 RIGHT OUTER JOIN t1.tid = t2.tid
效果类似于下图
4.内链接
inner join 查询两边都有的数据
SELECT t1.col1, t1.col2, t2.col1, t2.col2 FROM table_name1 AS t1, table_name2 AS t2 INNER JOIN t1.tid = t2.tid
5.全链接
full outer join 只要一个表中有数据,就都会查询出来
SELECT t1.col1, t1.col2, t2.col1, t2.col2 FROM table_name1 AS t1, table_name2 AS t2 FULL OUTER JOIN t1.tid = t2.tid
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)