• MySQL支持哪些存储引擎


    mysql支持九大存储引擎:

    1)MYISAM存储引擎(优点:可被转换为压缩、只读表来节省空间。)

               它管理的表具有以下特征:

                      使用三个文件表示每个表

                          格式文件-存储表结构的定义(mytable.frm)

                          数据文件-存储表行的内容(mytable.MYD)

                          索引文件-存储表上索引(mytable.MYI):索引是一本书的目录,缩小扫描范围,提高查询效率的一种机制,可被转换为压缩、只读表来节省空间。

    提示:对于一张表来说,只要是主键,或者加有unique约束的字段上会自动创建索引。

    2)InooDB存储引擎(优点:非常安全)

    这是mysql默认的存储引擎,同时也是一个重量级的存储引擎

    InooDB支持事务,支持数据库崩溃后自动恢复机制

    最大的特点:支持事务。以保证数据的安全性,效率不是很高,并且也不能压缩,不能转换为只读,不能很好的节省存储空间。

    3)MEMORY存储引擎(HEAP引擎)

    优点:查询效率是最高的

    缺点:不安全,关机后数据消失。因为数据和索引都是在内存当中

    使用memory存储引擎的表,其数据存储在内存中,且行的长度固定,这两个特点使memory存储引擎非常快。

    4)事务          一个事务就是一个完整的业务逻辑。是一个最小的工作单元,不可再分

    转账:A给B转账1000元

    A的账户-1000元(update语句),B的账户+1000元(update语句)

    这两条语句必须同时成功或者失败,这样才能保证钱是正确的。

    只有DML语句才有事务一说:insert增 delete删 update改

    只有以上三个语句是对数据库表中的数据进行增删改的,一旦涉及增删改就要考虑安全问题

    数据安全第一位

    本质上一个事务就是多条DML语句同时成功或者同时失败。

    提交事务commit:是一种全部成功的结束。

    回滚事务rollback:是一种全部失败的结束。

    mysql默认情况下是支持自动提交事务的。

    事务包括4个特性:

    A:原子性

    说明事务是最小的工作单元,不可再分

    C:一致性

    所有事务要求,在同一个事务当中,所有操作必须同时成功或同时失败,以保证数据的一致性。

    I:隔离性

    A事务和B事务具有一定的隔离

    墙越厚,隔离级别越高。

    D:持久性

    事务最终结束的一个保障。事务提交,相当于没有保存在硬盘上的数据保存在硬盘上。

    事务和事务之间的隔离级别有四个级别:

    1)读未提交 read uncommitted(没有提交就读到了):事务A可以读取到事务B未提交的数据。

    脏读dirty read:读到了脏数据。对方没有提交的数据我们认为是脏数据

    2)读已提交read committed(提交之后才能读到):事务A只能读取到事务B提交之后的数据。

    这种隔离级别解决了脏读现象

    存在的问题:不可重复读取数据(在事务开启之后,第一次读到的是三条,此时事务还没有结束,第二次再读读到的数据就变成了4条)

    这种隔离级别是比较真实的数据,每一次读到的数据是绝对的真实。

    是oracle数据库默认的隔离级别

    3)可重复读repeatable read(提交之后也读不到,永远读取到的都是刚开启事务时的数据

    解决了不可重复读的问题

    存在的问题:可能会出现幻读。(每一次读到的数据都是幻象,不够真实)

    是mysql默认的隔离级别

    4)序列化/串行化serializable(最高隔离级别)

    最高隔离级别,效率最低。解决了所有的问题。这种隔离级别表示事务排队,不能并发

    类似synchronized线程同步(事务同步)

    每一次读取到的数据都是最真实的,并且效率是最低的

  • 相关阅读:
    系统与应用监控的缜密思路
    odoo 开发入门教程系列-添加修饰
    使用 Docker Compose 快速搭建监控网站 uptime-kuma
    华为OD机试 - 用连续自然数之和来表达整数 - 滑动窗口(Java 2023 B卷 100分)
    JDBC实用详解
    mySQL创建表的基础命令
    SpringBoot基础知识和运行
    1.4+1.5 L1、L2正则化
    shell脚本自学笔记
    Transformer12
  • 原文地址:https://blog.csdn.net/qq_53120003/article/details/133138142