热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MySQL入门进阶(第四部分):深入浅出讲解核心概念与实用技巧

本文深入探讨了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

 


推荐阅读
author-avatar
Edwin
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有