数据库复习笔记:
规范化:
规范化的方法:
第一范式:任何一个关系数据库都满足第一范式
第二范式:在满足第一范式的基础上,所有的非码属性都由完整的主码决定
第三范式:满足第二范式的基础上,非码属性之间不存在函数依赖
BC范式:满足第三范式而且每个决定因子都是候选码
链接:https://www.cnblogs.com/lca1826/p/6601395.html
规范到BCNF步骤:
- 找出函数依赖
- 找出每个候选码
- 判断是否存在一个函数依赖其决定因子不是候选码:
A. 将这种函数依赖所对应的列移到一个新的关系
B. 使原来函数依赖的决定因子作为新关系的主码
C. 使原来函数依赖的决定因子作为旧关系的外码
D. 新关系与旧关系之间保证满足完整性约束
(没有比这还能解释规范化的了,辛苦地总结看博客是学习过程,但是找到靠谱精炼的内容就是命了)
SQL:
- 注意在连接查询中的几种情况:
- 子查询
SELECT SKU,SKU_Description, INVENTORY. WarehouseID
FROM INVENTORY
WHERE WarehouseID IN (
SELECT WarehouseID
FROM WAREHOUSE
WHERE Manager = ‘Lucille Smith’);
- join on
SELECT SKU, SKU_Description, INVENTORY. WarehouseID
FROM INVENTORY JOIN WAREHOUSE
ON INVENTORY. WarehouseID = WAREHOUSE.WarehouseID
WHERE Manager = ‘Lucille Smith’;
- where (and)
SELECT SKU, SKU_Description, INVENTORY. WarehouseID
FROM INVENTORY, WAREHOUSE
WHERE INVENTORY.WarehouseID=WAREHOUSE. WarehouseID AND Manager = ‘Lucille Smith’;
- 左连接和内连接:
-
inner join:
select * from person p inner join account a on p.id=a.id and p.id!=4 and a.id!=4;
- left join:
select * from person p left join account a on p.id=a.id and p.id!=4 and a.id!=4;
也就是说,左查询中包含所有前面表的行,并不在意这些行在后面表中有没有相关的匹配值存在。
原文博客:https://www.cnblogs.com/zzdbullet/p/10405540.html
- between and为闭区间:
相关资源:(博客,文档)
https://blog.csdn.net/qq_41380950/article/details/102940396