数据库复习资料
考试划重点
https://www.doc88.com/p-81661135033267.html
https://www.doc88.com/p-2098637045630.html
试卷
https://www.doc88.com/p-1723967451043.html?r=1
考试内容
填空题10分
选择题20分
分析题20
候选键,3NF,无损分解
问答题20
2PL
事务的隔离性
事务,读和写的程序
大题30
亚马逊的书籍数据库建立(er图10分,er图转化成表,写sql语句)
隔离级别
(一)可读取未确认(Read uncommitted)
写事务阻止其他写事务,避免了更新遗失。但是没有阻止其他读事务。
存在的问题:脏读。即读取到不正确的数据,因为另一个事务可能还没提交最终数据,这个读事务就读取了中途的数据,这个数据可能是不正确的。
解决办法就是下面的“可读取确认”。
(二)可读取确认(Read committed)
写事务会阻止其他读写事务。读事务不会阻止其他任何事务。
存在的问题:不可重复读。即在一次事务之间,进行了两次读取,但是结果不一样,可能第一次id为1的人叫“李三”,第二次读id为1的人就叫了“李四”。因为读取操作不会阻止其他事务。
解决办法就是下面的“可重复读”。
(三)可重复读(Repeatable read)
读事务会阻止其他写事务,但是不会阻止其他读事务。
存在的问题:幻读。可重复读阻止的写事务包括update和delete(只给存在的表加上了锁),但是不包括insert(新行不存在,所以没有办法加锁),所以一个事务第一次读取可能读取到了10条记录,但是第二次可能读取到11条,这就是幻读。
解决办法就是下面的“串行化”。
(四)可串行化(Serializable)
读加共享锁,写加排他锁。这样读取事务可以并发,但是读写,写写事务之间都是互斥的,基本上就是一个个执行事务,所以叫串行化
https://blog.csdn.net/w_linux/article/details/79666086?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522165701707516781667867003%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fall.%2522%257D&request_id=165701707516781667867003&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2allfirst_rank_ecpm_v1~hot_rank-3-79666086-null-null.142v31experiment_2_v1,185v2control&utm_term=%E6%95%B0%E6%8D%AE%E5%BA%93%E4%BA%8B%E5%8A%A1&spm=1018.2226.3001.4187