作者:Edwin | 来源:互联网 | 2024-11-01 19:25
本文深入探讨了MySQL数据库设计的核心概念与实用技巧,重点讲解了数据库设计的三范式。第一范式要求每个表都应具备主键,并确保所有字段具有原子性,即不可再进一步分割。第二范式则在此基础上进一步规范,确保所有非主键字段完全依赖于主键,避免部分依赖带来的数据冗余问题。第三范式则进一步消除传递依赖,确保非主键字段之间不存在依赖关系,从而提高数据的一致性和完整性。通过这些范式的应用,可以有效提升数据库的设计质量和性能。
数据库设计三范式
第一范式:任何一张表都应该有主键,并且每一个字段原子性不可再分
第二范式:建立在第一范式的基础上,非主键字段完全依赖主键,不能产生部分依赖 多对多,三张表,关系表两个外键
第三范式:建立在第二范式的基础上,所有非主键字段不能传递依赖于主键字段 一对多,两张表,多的表加外键
在实际开发中,以满足客户需求为主,有时候会拿冗余换执行速度
一对一表的设计:主键共享或者外键唯一
练习题:查询各部门工资最高的人
selecte.name, t.*
from emp e
join(select deptno, max(sal) as maxsal from emp group by deptno) t
on t.deptno = e.deptno and t.maxsal = e.sal;
练习题:不用max选出收入最高的人的两种方法
第一种:自连接 第二种:order+limit
select sal
fromemp
wheresal not in(select distinct a.sal from emp a join emp b on a.sal 练习题: 列出薪酬高于公司平均薪酬的所有员工,所在部门,上级领导,雇员的薪资等级
select e.name'员工', d.dname, l.ename'领导', s.grade
from emp e
join dept d
one.deptno = d.deptno
left joinemp l
one.mgr = l.empo
joinsalgrade s
one.sal between s.losal and s.hisal
wheree.sal > (select avg(sal) from emp);
练习题:列出薪酬等于部门30员工的薪酬的其他员工的姓名和薪酬
select ename,sal
fromemp
where sal in (select distinct sal from emp where deptno = 30)
anddeptno <> 30;
练习题&#xff1a;列出每个部门工作的员工数量&#xff0c;平均工资和平均服务期限
select d.deptno, count(e.name), ifnull(avg(e.sal),0), ifnull(avg(timestampdiff(YEAR,hiredate,now())), 0)
from emp e
right join dept d
one.deptno &#61; d.deptno
group byd.deptno