美文网首页
数据库设计——向着第三范式努力

数据库设计——向着第三范式努力

作者: 名锤青史 | 来源:发表于2016-10-21 10:25 被阅读65次

虽然,不在专业的IT公司工作,但我因为我的专业背景而骄傲。其实,教育背景也只是半专业的带有“师范”后缀的“计算机科学”,但我因为我的专业信仰而自豪。

Learnsite是在我的学校中每节信息技术课都要使用的在线学习系统。它很好用,但并不完美。同时,又为了在职读研的毕业论文,我决定再一次挑(折)战(磨)自己——自己动手写一个信息技术课在线学习系统。

Learnsite中的数据库设计有很大的问题。一张学生表,把年级、班级、作业成绩、表现成绩等等全放进去,十分的冗余。所以自己设计的时候,就把它们分成了多个实体。今天,我又依稀地想起了这个术语“第三范式”。找到了理论依据(没想到我也能说出这么“学术”的话),就可以更好的指导我的数据库设计了。

其实,我设计的数据库也不一定符合那些理论,但总感觉舒心了很多。各实体分得比较散,怎么输出一张综合统计表呢?学过的东西在关键的时候还真是有用,若干年过去,心里就只剩下一个个一闪而过的关键词——它也是决定人的专业方向的关键因素。通过搜索,你就可以再次拾起这些知识。

今天就设计了这么几个表:

年级班级表:grade_classes 学生信息表:students 表现得分表:performance_score

把Learnsite中的一张大表拆分成这样几张小表,感觉清爽了很多。但是,如果想要查询一年级一班(grade_num=1 & class_num=1)学生分表得分的汇总表怎么办呢?

我突然灵光一闪,想起了使用JOIN关键词连接学生信息表和表现得分表,再根据给出的年级班级号得出班级代码,最后使用班级代码对前边的结果进行筛选(快转晕了)。经过一番努力,得出了下边的SQL:

SELECT
students.student_number, students.student_name, score
FROM
students
JOIN
(
SELECT
    performance_score.student_number, SUM(performance_score.delta_score) AS score
    FROM
    performance_score
    GROUP BY
    performance_score.student_number
)
AS per_s
ON
students.student_number = per_s.student_number
WHERE
students.class_code IN
(
    SELECT
    grade_classes.class_code
    FROM
    grade_classes
    WHERE
    grade_classes.grade_num = 1
    AND
    grade_classes.class_num = 1
)

最后的汇总结果也符合预期:


一年级一班学生表现得分汇总表

这样就可以放心大胆地拆分表了,因为学艺不精,也没法说这么做是否合适,不断努力吧!

相关文章

  • 数据库设计——向着第三范式努力

    虽然,不在专业的IT公司工作,但我因为我的专业背景而骄傲。其实,教育背景也只是半专业的带有“师范”后缀的“计算机科...

  • (系列7)数据库

    MySQL 数据库概念 范式 范式是数据库设计规范,范式越高则数据库冗余越小,但查询也更复杂,一般只需满足第三范式...

  • java_sql数据库的设计

    数据库设计三范式(重点) 1.什么是设计范式 2.设计范式是哪些 3.第三范式 是建立在第二范式基础上 所有非主键...

  • 多对一关系

    数据库表关联设计关系型数据库:第三范式:严格的关联关系的处理第三范式(Third Normal Form,3rd ...

  • MySQL数据库基础知识

    数据库三大设计范式 其实,目前的关系数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、...

  • java面试题杂谈

    #数据库三大范式: 第一范式:属性不可再分; 第二范式:消除冗余; 第三范式:消除函数传递依赖。 #设计模式 1....

  • 数据库四大范式

    参考来源 解释一下关系数据库的第一第二第三范式? 第一,二,三和四范式 数据库设计范式2——BC范式和第四范式 主...

  • 范式

    数据库(第一范式,第二范式,第三范式)

  • 数据库设计三范式与反范式

    MySql设计与优化系列笔记:一、数据库设计三范式与反范式二、MySql表设计与优化 第一范式: 1、数据库的所有...

  • 数据库设计范式

    数据库设计三大范式 数据库设计范式 什么是范式:简言之就是,数据库设计对数据的存储性能,还有开发人员对数据的操作都...

网友评论

      本文标题:数据库设计——向着第三范式努力

      本文链接:https://www.haomeiwen.com/subject/ugsfuttx.html