My SQL数据库实用技术(04)
时间:2007-12-23 来源:不详 作者:迈克DB
此查询与前一个查询的差别在于:
■ student 表被增加到了FROM 子句中,因为除了event 表和score 表外还用到了它。
■ student_id 列现在不明确了(因为现在有两个引用到的表都含有此列),因此必须限定为score.student_id 或student.student_id 以表明使用的是哪个表。
■ WHERE 子句有一个附加项,它说明根据学生ID 将score 表记录与student 表记录进行匹配。
■ 此查询是显示学生名而不是学生I D。(当然,假如愿意的话,可以两者都显示。)利用此查询,可以加入任意日期,得到该日期的学分,用学生名和学分类型完善查询结果。不一定要了解关于学生ID 或事件ID 的情况。MySQL 小心地得出相关的ID 值并利用它们自动地使各表的行相配。
学分保存方案涉及的另一项工作是汇总学生的缺勤情况。缺勤情况是按学生ID 和日期在absence 表中记录的。为得到学生名(而不仅仅是I D),我们需要根据student_id 的值将absence 表连接到student 表。下面的查询给出了学生的ID 号和名字以及缺勤计数:
注重:虽然我们在GROUP BY 子句中应用了一个限定符,但对于这个查询来说不是必须的。因为GROUP BY 子句只引用选择表中(此查询的前两行)的列。在该处只有一个名为student_id 的列,因此MySQL 知道应该用哪个列。这个规则对ORDER BY 子句也成立。假如我们希望只了解哪些学生缺过勤,则此查询所产生的输出也是有用的。但是,假如我们将此清单交给学校办公室,他们可能会说,“其他的学生呢?我们需要每个学生的情况。”这是一个稍微有点不同的问题。它表示需要知道学生的缺勤数,即使没有缺勤的学生也需要知道。因为问题的不同,查询也应该不同。 内容来自dedecms
为了解决上述问题,使用LEFT JOIN 而不涉及WHERE 子句中的学生I D。LEFT JOIN要求MySQL 对从连接首先给出的表中选择每行生成一个输出行(即LEFT JOIN 要害字左边给出的表)。由于首先给出student 表,我们得到了每个学生的输出结果,即使是那些在absence 表中未给出的学生也都包括在输出中。此查询如下:
前面,在“生成汇总”一节中,我们执行了一个查询,它生成score 表中数据的数值特征。该查询的输出列出了事件I D,但不包括学分日期或类型,因为我们不知道怎样将score 表连接到event 表以得到学分的日期和类型。现在可以做到了。下面的查询类似于早先的那个,但是它给出了学分的日期和类型而不只是简单的数字事件I D:
可利用诸如COUNT( ) 和AVG( ) 这样的函数生成多个列上的汇总,即使这些列来自不同的表也是如此。下面的查询确定学分数,以及事件日期与学生性别的每种组合的平均学分。
我们可以使用一个类似的查询来完成学分保存方案的一个任务,即在学期末计算每个学生的总学分。相应的查询如下: 本文来自织梦
不一定要求连接必须用两个不同的表来完成。这似乎有点希奇,但是确实可以将一个表连接到其自身。例如,可通过针对每个总统的出生地查看其他各个总统的出生地,确定几个总统是否出生在相同城市。此查询如下:
上一篇:My SQL数据库实用技术(02) 下一篇:My SQL数据库实用技术(03)
文章评论
共有位Admini5网友发表了评论 查看完整内容