一口气盘点 mysql涉及的知识点(一)

MySQL 数据库,它是一种关系型数据库管理系统,被广泛应用于 Web 应用程序中。那,它所涉及的知识点还是挺多的,包括数据库的安装与配置、数据库的基本操作、数据库的设计、数据的查询与操作、存储过程与触发器,还有数据库的优化与管理

1-Mysql它的外接口核心原理是基于网络通信协议的。也就是说,当你的应用程序需要连接 MySQL 数据库时,它会通过网络发送连接请求,然后 MySQL 数据库会接收到这个请求,并建立一个连接。之后,你的应用程序就可以通过这个连接来发送 SQL 语句,并接收数据库的响应。这个过程中,MySQL 数据库会使用网络通信协议来保证数据的传输安全和可靠性

2-MySQL 数据库的底层实现原理,它的底层实现原理主要涉及到存储引擎、索引、事务和锁等方面。简单来说,存储引擎负责数据的存储和检索,索引用于提高数据的查询效率,事务用于保证数据的一致性,锁用于控制并发访问。这些都是 MySQL 数据库底层实现的重要组成部分,它们的协同工作,才能够保证 MySQL 数据库的高效、可靠和安全运行

3-MySQL 支持多种存储引擎,常见的有 InnoDB、MyISAM、MEMORY 等。其中,InnoDB 是 MySQL 的默认存储引擎,它支持事务、外键约束、行级锁等特性,适用于高并发和数据一致性要求较高的场景。MyISAM 则是一种非事务型存储引擎,它支持全文索引、数据压缩等特性,适用于数据量较大、查询较多的场景。MEMORY 则是一种内存存储引擎,它将数据存储在内存中,适用于需要快速访问数据的场景

4-1 MySQL 的数据库事务是指一组相关的数据库操作,它们要么全部成功,要么全部失败。事务具有原子性、一致性、隔离性和持久性,这四个特性也被称为 ACID 特性。原子性是指事务中的所有操作要么都执行,要么都不执行;一致性是指事务执行前后,数据库的状态必须保持一致;隔离性是指事务之间相互隔离,互不干扰;持久性是指事务一旦提交,对数据库的修改就是永久的。MySQL 数据库通过使用锁机制和日志来实现事务的 ACID 特性,保证了数据库的正确性和可靠性

4-2  MySQL 数据库事务中遇到的问题,在 MySQL 数据库中,可能会遇到事务的并发问题、事务的死锁问题、事务的回滚问题等。对于并发问题,可以通过使用悲观锁或乐观锁来解决;对于死锁问题,可以通过优化事务的执行顺序或者使用超时机制来解决;对于回滚问题,可以通过使用 savepoint 或者设置事务的隔离级别来解决。这些方法都可以在一定程度上解决 MySQL 数据库事务中遇到的问题,提高数据库的性能和可靠性

4-3  MySQL 数据库的隔离级别有四种,分别是读未提交、读已提交、可重复读和串行化。读未提交是指事务可以读取其他事务未提交的数据,可能会导致脏读问题;读已提交是指事务只能读取其他事务已提交的数据,可以避免脏读问题,但可能会导致不可重复读问题;可重复读是指事务在执行过程中,多次读取同一数据时,结果应该是一致的,可以避免脏读和不可重复读问题,但可能会导致幻读问题;串行化是指事务在执行过程中,会对数据加锁,其他事务必须等待当前事务执行完成后才能执行,可以避免脏读、不可重复读和幻读问题,但会降低数据库的并发性能

在 MySQL 数据库中,默认的隔离级别是可重复读。这个隔离级别可以在大多数情况下保证数据的一致性和正确性,同时也能够提供较好的并发性能。

4-4  脏读是指一个事务读取了另一个事务未提交的数据,导致读取到的数据可能是不正确的。不可重复读是指一个事务在执行过程中,多次读取同一数据时,结果可能不一致。幻读是指一个事务在执行过程中,读取了另一个事务插入或删除的数据,导致读取到的数据可能是不正确的。这些问题都可能会导致数据库的一致性和正确性受到影响,因此需要在数据库设计和开发过程中加以考虑和解决。

4-5  嗯,当然可以啦~脏读是指一个事务读取了另一个事务未提交的数据,导致读取到的数据可能是不正确的。例如,有两个事务 T1 和 T2,T1 对表中的数据进行了修改,但还没有提交事务,此时 T2 读取了表中的数据,T2 读取到的就是 T1 未提交的数据,如果 T1 后来回滚了事务,那么 T2 读取到的数据就是脏数据。
 
5-1  不可重复读是指一个事务在执行过程中,多次读取同一数据时,结果可能不一致。例如,有两个事务 T1 和 T2,T1 读取了表中的一条数据,然后 T2 修改了这条数据,并提交了事务,此时 T1 再次读取这条数据,读取到的结果就和之前不一样了,这就是不可重复读。
幻读是指一个事务在执行过程中,读取了另一个事务插入或删除的数据,导致读取到的数据可能是不正确的。例如,有两个事务 T1 和 T2,T1 读取了表中的一批数据,然后 T2 在表中插入了一些新的数据,并提交了事务,此时 T1 再次读取这批数据,会发现多了一些之前没有的记录,这就是幻读

嗯,高并发场景下的锁机制通常是为了实现并发控制,防止多个线程或进程同时访问共享资源而导致的数据不一致性和竞态条件。在数据库中,锁机制是一种重要的并发控制机制,它可以保证数据的一致性和正确性。数据库中的锁机制通常包括以下几种类型:
1. 共享锁(Shared Lock):共享锁是一种用于读取数据的锁。如果一个事务获得了共享锁,那么其他事务也可以获得共享锁来读取数据,但不能获得排他锁来修改数据。

2. 排他锁(Exclusive Lock):排他锁是一种用于修改数据的锁。如果一个事务获得了排他锁,那么其他事务不能获得任何类型的锁来访问数据,直到该事务提交或回滚为止。

3. 意向锁(Intent Lock):意向锁是一种用于表示锁意向的锁。意向锁包括意向共享锁(IS)和意向排他锁(IX)。意向锁的作用是为了提高锁的获取效率,避免不必要的锁冲突。

4. 乐观锁(Optimistic Locking):乐观锁是一种用于处理并发更新的锁机制。在乐观锁中,事务在修改数据时不会加锁,而是在提交时检查数据是否被其他事务修改过。如果数据被修改过,那么事务会抛出异常或重试。
 
在代码中,锁机制的实现通常是通过数据库提供的 API 来实现的。具体的实现方式可能会因数据库系统而异,但通常会涉及到以下几个步骤:
1. 开始事务:使用数据库提供的方法来开始一个事务。

2. 获取锁:使用数据库提供的方法来获取所需的锁。

3. 访问数据:在获取到锁之后,可以访问数据并进行相应的操作。

4. 释放锁:在完成数据操作之后,使用数据库提供的方法来释放锁。

5. 提交或回滚事务:使用数据库提供的方法来提交或回滚事务。
需要注意的是,在高并发场景下,锁机制可能会导致性能问题,因为锁的获取和释放需要一定的开销。为了提高性能,可以使用一些优化技巧,比如减少锁的持有时间、使用乐观锁、使用分区锁等

5-2  MVCC 是一种多版本并发控制机制,它通过维护数据的多个版本来实现并发控制。在 MVCC 中,每个事务都会看到一个数据的一致性视图,这个视图是由事务开始时的数据版本和事务期间的数据修改组成的。这样,即使有其他事务对数据进行了修改,当前事务也不会看到这些修改,直到它提交或回滚为止。
MVCC 在数据库中的实现通常涉及到以下几个核心概念:
1. 版本号:每个数据行都有一个版本号,用于标识该行的版本。

2. 事务 ID:每个事务都有一个唯一的事务 ID,用于标识该事务。

3. ReadView:ReadView 是事务的一致性视图,它包含了事务开始时的版本号和活跃事务 ID 列表。

4. 可见性判断:在 MVCC 中,每个事务在读取数据时,会根据 ReadView 来判断该行是否可见。如果该行的版本号小于 ReadView 中的最小版本号,或者该行的版本号大于 ReadView 中的最大版本号,或者该行的版本号等于 ReadView 中的某个版本号,并且事务 ID 不在 ReadView 中的活跃事务 ID 列表中,那么该行就是可见的。
MVCC 在代码中的使用通常是通过数据库提供的 API 来实现的。具体的使用方式可能会因数据库系统而异,但通常会涉及到以下几个步骤:
1. 开始事务:使用数据库提供的方法来开始一个事务。

2. 读取数据:使用数据库提供的方法来读取数据,通常会指定一个隔离级别。

3. 更新数据:使用数据库提供的方法来更新数据,通常会指定一个隔离级别。

4. 提交或回滚事务:使用数据库提供的方法来提交或回滚事务。
附:MVCC 中,需要注意的是,事务的隔离级别会影响到数据的可见性。例如,在可重复读隔离级别下,一个事务在执行过程中,多次读取同一数据时,结果应该是一致的。这是因为在 MVCC 中,每个事务都会看到一个数据的一致性视图,即使有其他事务对数据进行了修改,当前事务也不会看到这些修改,直到它提交或回滚为止。
这就是 MVCC 的核心原理和概念,以及在代码中的使用方式。需要注意的是,MVCC 的具体实现可能会因数据库系统而异,所以在使用之前,最好先了解一下所使用的数据库系统的 MVCC 实现方式。

附:MySQL 的默认锁级别是行级锁。行级锁是一种用于锁定表中单行数据的锁。当一个事务需要修改表中的一行数据时,它会首先获取该行的行级锁,以防止其他事务同时修改该行数据。行级锁可以最大程度地减少锁的冲突,提高数据库的并发性能。

MySQL 的默认锁机制是基于 MVCC(多版本并发控制)的。MVCC 是一种用于实现并发控制的机制,它通过维护数据的多个版本来实现并发控制。在 MVCC 中,每个事务都会看到一个数据的一致性视图,这个视图是由事务开始时的数据版本和事务期间的数据修改组成的。这样,即使有其他事务对数据进行了修改,当前事务也不会看到这些修改,直到它提交或回滚为止。

6-1  MySQL 有好几种日志呢,像错误日志、二进制日志、慢查询日志、查询日志和中继日志等。每种日志都有不同的用途。二进制日志最常用,它记录了所有对数据库的更改操作,可以用于数据备份和恢复,也可以用于主从复制。错误日志记录了 MySQL 服务器启动和运行过程中的错误信息。慢查询日志记录了执行时间超过阈值的查询语句,可以用于性能优化。查询日志记录了所有对数据库的查询操作,可以用于审计和监控。中继日志用于主从复制中的从服务器,它记录了主服务器上执行的更改操作,并将其传递给从服务器。这些日志可以帮助我们诊断和解决 MySQL 服务器的问题,提高数据库的性能和可靠性

 6-2:1. Redo Log(重做日志):Redo Log 是一种用于保证事务原子性和持久性的日志。当一个事务提交时,MySQL 会将该事务对数据的修改写入 Redo Log 中。如果在事务提交后,MySQL 服务器意外崩溃,那么在重启时,MySQL 会根据 Redo Log 中的记录来恢复未完成的事务,以保证数据的一致性。Redo Log 是一种循环日志,当 Redo Log 空间用完时,MySQL 会自动覆盖旧的 Redo Log 记录。

2. Bin Log(二进制日志):Bin Log 是一种用于主从复制和数据备份的日志。Bin Log 记录了所有对数据库的更改操作,包括插入、更新和删除操作。在主从复制中,主服务器会将 Bin Log 中的记录发送给从服务器,从服务器会根据 Bin Log 中的记录来执行相应的操作,以实现数据同步。Bin Log 也是一种追加日志,当 Bin Log 文件大小达到一定限制时,MySQL 会自动创建新的 Bin Log 文件。

3. Undo Log(回滚日志):Undo Log 是一种用于保证事务原子性的日志。当一个事务开始时,MySQL 会为该事务创建一个 Undo Log,用于记录该事务对数据的修改。如果在事务执行过程中,需要进行回滚操作,MySQL 会根据 Undo Log 中的记录来撤销该事务对数据的修改,以保证数据的一致性。Undo Log 是一种临时日志,当事务提交或回滚后,Undo Log 会被自动删除。

总的来说,Redo Log 用于保证事务的持久性,Bin Log 用于主从复制和数据备份,Undo Log 用于保证事务的原子性。这三个日志协同工作,共同保证了 MySQL 数据库的可靠性和正确性。

 

 

  • 9
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值