一、主键,外键,超键,候选键;
超键 | 在关系中能唯一标识元组的属性集,里面可能包含很多能唯一标识元组的属性 |
候选键 | 不含有多余属性的超键,即它里面的属性一旦去掉任何一个,它就不是超键 |
主键 | 用户选作元组标识的一个候选键 |
外键 | 该列为另一表的主键; |
二、数据库范式
1NF | 每一列都是不可分割的基本数据项,同一列无二值;无重复的域; |
2NF | 每一个非主属性完全依赖于任何一个候选键 |
3NF | 每一个非主属性即不传递依赖于码,也不部分依赖于码 |
BCNF | 没有任何属性完全函数依赖于非码的任何一组属性 |
三、数据库事务的四个特征及含义;
原子性 | 要么全部完成,要么不完成,若发生错误会进行回滚操作; |
一致性 | 开始到结束后,数据库完整性约束没收到破坏;(实体完整性,参照完整性,用户定义的完整性) |
隔离性 | 事务与事务之间相隔离,串行化执行; |
持久性 | 事务完成对数据的影响是永久的; |
四、事务的并发问题
脏读 | 事务A读取了事务B更新的数据,然后B回滚操作,那么A读取到的数据是脏数据 |
不可重复读 | 事务 A 多次读取同一数据,事务 B 在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果 不一致。 |
幻读 | 系统管理员A操作数据库时,管理员B在这个时候插入了一条新的记录,当系统管理员A改结束后发现还有一条记录没有改过来,就好像发生了幻觉一样,叫做幻读。 |
不可重复读的和幻读很容易混淆,不可重复读侧重于修改,幻读侧重于新增或删除。解决不可重复读的问题只需锁住满足条件的行,解决幻读需要锁表
五、MySQL事务隔离级别
事务隔离级别 | 脏读 | 不可重复读 | 幻读 |
读未提交(read-uncommitted) | 是 | 是 | 是 |
不可重复读(read-committed)(读已提交) | 否 | 是 | 是 |
可重复读(repeatable-read) | 否 | 否 | 是 |
串行化(serializable) | 否 | 否 | 否 |
不可重复读:A读数据,未提交,B读数据,提交。A再读数据,发现数据变了
可重复读:A读数据是100,未提交。B改数据为200,提交。A再次读数据还是100
1、mysql中默认事务隔离级别是可重复读时并不会锁住读取到的行
2、事务隔离级别为读提交时,写数据只会锁住相应的行
3、事务隔离级别为可重复读时,如果有索引(包括主键索引)的时候,以索引列为条件更新数据,会存在间隙锁、行锁、下一键锁的问题,从而锁住一些行;如果没有索引,更新数据时会锁住整张表。
4、事务隔离级别为串行化时,读写数据都会锁住整张表
5、隔离级别越高,越能保证数据的完整性和一致性,但是对并发性能的影响也越大,鱼和熊掌不可兼得啊。对于多数应用程序,可以优先考虑把数据库系统的隔离级别设为Read Committed,它能够避免脏读取,而且具有较好的并发性能。尽管它会导致不可重复读、幻读这些并发问题,在可能出现这类问题的个别场合,可以由应用程序采用悲观锁或乐观锁来控制。
六、乐观锁和悲观锁
乐观锁 | 假定不会发生并发冲突,只在提交时检查,若有其他数据更新了数据,则回滚;使用数据版本标示数据(时间戳,版本号) |
悲观锁 | 假定会发生并发冲突,屏蔽一切破坏数据库一致性的操作,主要用于数据争用激烈的环境,以及锁成本低于回滚成本时;排他锁; |
七、 存储过程与触发器的区别
存储过程:
是一些预编译(整个编译过程的最先做的工作)的SQL语句。存储过程可以说是一个记录集,它是由一些T-SQL语句组成的代码块,这些T-SQL语句代码像一个方法一样实现一些功能(对单表或多表的增删改查),然后再给这个代码块取一个名字,在用到这个功能的时候调用他就行了。它可以降低网络通信量,提高通信速率
触发器:
不可用CALL调用,而是在用户执行某些语句后自动调用;
八、连接的种类
内部联接(等值联接) | INNER JOIN |
外部联接(包含在相关表中没有关联行的行) | LEFT OUTER JOIN |
RIGHT OUTER JOIN | |
FULL OUTER JOIN |
九、两种存储引擎索引的区别
Innodb | 主索引的数据文件本身就是索引文件(这棵树的叶节点数据域保存了完整的数据记录);辅助索引记录主键的值; |
支持事务,外键,行锁,查表总行数时,全表扫描; | |
MyISAM | 主索引数据文件和索引文件分离;辅助索引与主索引无区别; |
不支持事务,不支持外键,表锁;插入数据时锁定整个表,查行数时无需整表扫描 |
内容整理自: