软件设计师(4)数据库

关系模型:用二维表格表达实体类型与实体间联系

3/2

三级模式:外模式(视图);概念模式(基本表);内模式(存储文件)

两级映像:外模式/概念模式映像(逻辑独立性);模式/内模式映像(物理独立性)

总结:视图------外模式------逻辑独立

关系模型

关系模型完整性约束:

(1)实体完整性:主码不为空

(2)参照完整性

(3)用户自定义完整性

关系的运算

并,差,交,笛卡尔积

选择

selsect...b=5,也就是选择b=5的那一行

投影

关系表中有ABC,对AC进行投影就是把AC提取出来

连接

斯塔连接:先进行笛卡尔积,再进行选取

等值连接:先进行笛卡尔积,再进行选取

自然连接:去重后的等值连接(((最常考,就是把相等的两列合并成一列

SQL语言

投影------>SQL:select ... from ...

选择------>where....

笛卡尔积------>from R,S

自然连接------>select时不写重复的

自然连接后对表格中的需要重新排序(R中有b,c,S中也有,需要排除S中的接着R后面排次序)

AVG(单价) AS 平均单价:对求出的AVG(单价)起一个别名,叫做平均单价

where后面不能跟聚合函数

权限:with grant option

视图:with check option

索引改变的是内模式

闭包

A->B,则A是候选关键字,不被任何别的决定

主码:一个

候选码:多个(AC,AB)

主属性:包含在候选关键字的属性(A,B,C)

冗余:若A1-A2,A2-A4,则能推出A1-A4,推导出来的这个就是冗余的

第一范式

每个属性不可以再进行分割,但可能存在部分函数依赖,不能排除数据冗余与更新异常(修改姓名需要修改所有含姓名的数据)

第二范式

每个非主属性完全依赖候选码,包含传递函数。消除部分依赖

但是数据冗余减少了,数据更新仍存在异常

第一范式分解成第二范式:把一个表分解成多个表,让非主属性完全依赖于主属性

第三范式

每个非主属性非传递函数依赖于候选码。消除了传递依赖

第二范式分解第三范式:继续把传递依赖分解成两个表

学号------>学院;学院------>院长

从学号,学院,院长分解成:

1.学号,学院

2.学院,院长

第三范式规范化:BC范式

消除主属性对码的传递依赖(所有属性都是主属性!!)

已经消除插入与删除异常,消除主属性对码的部分与传递依赖

部分函数依赖:看是否只依赖主属性的其中一部分

传递函数依赖

无损连接

对分解的子关系进行自然连接,找公共属性列

数据库设计

1.需求分析

2.概念结构设计

E-R模型:实体用矩形,联系用菱形,属性用椭圆

派生属性:年龄。可以通过出生年月得到

多值属性:联系方式。个人电话和办公室电话

复合属性:家庭住址。记录了邮编,省,市,街道信息

弱实体:职工的家属。依赖于职工

冲突:(1)属性冲突:同一属性存在不同的图中;

(2)命名冲突:同一属性在不同图中命名不同,或者命名相同的代表不同含义;

(3)结构冲突:同一实体在不同图中有不同属性

3.逻辑结构设计

共享锁:只能读,能加锁但只能加共享锁

排他锁:加了之后不能再加其他任何类型锁

相关推荐
.小小陈.2 小时前
MySQL 高频考点:表连接与索引全解析
数据库
阳光九叶草LXGZXJ2 小时前
达梦数据库-学习-57-读写数据页超时告警排查(page[x,x,xxxxxx] disk write uses)-DSC集群版
linux·运维·服务器·数据库·sql·学习
Omics Pro2 小时前
前沿学科:量子生物学!
大数据·数据库·人工智能·windows·redis·量子计算
霸道流氓气质2 小时前
Spring 事务提交后执行异步操作:原理、陷阱与最佳实践
数据库·spring
无小道2 小时前
Redis——list相关指令
数据库·redis·缓存
阳光九叶草LXGZXJ2 小时前
达梦数据库-堆栈看问题-01-asmapi_asm_extent_load
linux·运维·数据库·sql·学习
你的保护色2 小时前
ensp之STP、RSTP、MSTP协议实验
java·服务器·数据库
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ3 小时前
获取容器mysql管理员密码命令
数据库·mysql
JAVA学习通3 小时前
《大营销平台系统设计实现》 - 营销服务 第5节:抽奖前置规则过滤
java·数据库·github