mysql 知识总结

一、主键,外键,超键,候选键;

超键在关系中能唯一标识元组的属性集,里面可能包含很多能唯一标识元组的属性
候选键不含有多余属性的超键,即它里面的属性一旦去掉任何一个,它就不是超键
主键用户选作元组标识的一个候选键
外键

该列为另一表的主键;

二、数据库范式

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主索引数据文件和索引文件分离;辅助索引与主索引无区别;
 不支持事务,不支持外键,表锁;插入数据时锁定整个表,查行数时无需整表扫描

 

内容整理自:

https://blog.csdn.net/weinierzui/article/details/71054964

https://blog.csdn.net/u011010851/article/details/80074550

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值