zoukankan      html  css  js  c++  java
  • Mysql系统知识梳理

    1 数据库分类

      MySQL Oracle redis 

    2 MySQL 存储引擎有哪些

      ENGINE=InnoDB 提供事务安全表,支持外键。

      MyISAM

      Memory数据存入内存中,如果内存出现异常或事重启关机,所有数据都会消失

    3 事务

      概念:逻辑上的一组sql语句,组成这组操作的sql语句,要么成功,要么失败。

    3.1 事务四大特性ACID

      原子性(Atomicity):事务是一个不可分割的单位,事务中的sql语句,要么全都发生,要么都不发生。

      一致性(Consistency):事务发生前后,数据的完整性必须保持一致。

      隔离性(Isolation):当并发访问数据库的时候,一个正在执行的事务在执行完前,对于其他的会话是不可见的,多个并发的事务之间的数据库相互隔离。

      持久性(Durability):一个事务一旦被提交,数据库中的数据改变就是持久性的。如果出了错误也不能撤销。

    3.2 事务隔离级别

      对于同时运行的几个事务,当这些事务同时访问数据库时,如果不采取隔离措施就会导致各种并发问题。由此引出隔离级别的概念,总有4个,由低到高,可逐步解决脏读,不可重复读,幻读等问题。

      Default spring:默认隔离级别,使用数据库默认的事务隔离级别

      read_uncommitied:读未提交,一个会话可以读取其他事务未提交的更新结果,一旦这个事务被回滚了,导致这个会话的结果不正确了。

      read_commited:读已提交,一个会话只能读取其他事务已经提交的更新结果,否则,等待。但是其他会话可以修改这个事务中被读取的记录,而不必等待事务结束。导致了,一个事务中两个相同的读取操作,其结果可能不同。

      repeatable_read:重复读取,在数据读取出来后加锁,直到这个事务执行结束。

      serlalizable:串行化,不管多少事务,只有执行完一个事务的所有子事务后,才可以执行另外一个事务里的所有子事务。

    3.3 数据库设置的隔离级别read_commited

      可以避免脏读,且具有较好的并发性能,可能出现的问题场景,可以使用悲观锁或乐观锁控制。

    4 悲观锁和乐观锁,以及使用场景

      悲观排他后,不能修改数据,即在数据被操作的时候,锁定数据不被访问。

      乐观排他后,可以修改数据,即假设数据一般情况下不会造成冲突。

    5 如何实现分页

       使用sql语句关键字limit

    6 数据库三大范式

    1NF:对属性的原子性约束,要求属性具有原子性,不可再分解。

    2NF:对记录的惟一性约束,要求记录有惟一标识,即实体的惟一性。

    3NF:对字段冗余性的约束,即任何字段不能由其他字段派生出来,它要求字段没有冗余。

    7 Mysql有哪些索引:fulltext、hash、btree、rtree

    8 什么时候该建立索引

      1)表的主键、外键必须有索引

      2)数据量超过300的表应该有索引

      3)经常与其他表进行连接的表,在连接字段上应该建立索引

      4)经常出现在where子句中的字段,特别是大表的字段,应该建立索引

    9 sql关键字执行顺序:select->from->where->group by->having->order by

    10 explain包含哪些列


    如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!

  • 相关阅读:
    第二阶段团队冲刺第二天站立会议
    第二阶段冲刺第一天站立会议
    对身边常用的软件进行评价
    学习进度条
    进度条
    团队冲刺第四天站立会议
    用户模板及场景分析
    团队冲刺第一天战略会议
    团队冲刺第九天
    团队冲刺第八天
  • 原文地址:https://www.cnblogs.com/guobm/p/9970412.html
Copyright © 2011-2022 走看看