1、MySQL数据库中支持的事务隔离级别有哪些?
A、读未提交(Read Uncommitted)
B、只读事务(Read Only)
C、序列化读(Serializable)
D、可重复读(Repeatable Read)
E、读提交(Read Committed)
2、insert语句属于sql语句中的哪一种类型?A
A、DML
B、DBS
C、DDL
D、DQL
3、以下哪项用于左连接?C
A、join
B、right join
C、left join
D、inner join
MySQL是一个客户端/服务器架构的软件,对于同一个服务器来说,可以有若干个客户端与之连接,每个客户端与服务器连接上之后,就可以称之为一个会话(Session)。每个客户端都可以在自己的会话中向服务器发出请求语句,一个请求语句可能是某个事务的一部分,也就是对于服务器来说可能同时处理多个事务。当数据库上有多个事务同时执行的时候,就可能出现脏读(Dirty Read)、不可重复读(Non-Repeatable Read)、幻读(Phantom Read)的问题,为了解决这些问题,就有了 “隔离级别” 的概念。
理论上在某个事务对某个数据进行访问时,其他事务应该进行排队,当该事务提交之后,其他事务才可以继续访问这个数据。但一般情况下隔离得越严实,效率就会越低。因此很多时候,我们都要在隔离性和效率二者之间寻找一个平衡点。
ISO 和 ANIS SQL 标准制定了四种事务隔离级别的标准,分别为:读未提交(read uncommitted)、读提交(read committed)、可重复读(repeatable read)和串行化(serializable )。
我们先来看下这四种隔离级别的意思。
读未提交: 一个事务还没提交时,它做的变更就能被别的事务看到。
读提交: 一个事务提交之后,它做的变更才会被其他事务看到。
可重复读: 一个事务执行过程中看到的数据,总是跟这个事务在启动时看到的数据是一致的。当然在可重复读隔离级别下,未提交的变更对其他事务也是不可见的。
串行化: 顾名思义是对于同一行记录,“写”会加“写锁”,“读”会加“读锁”。当出现读写锁冲突的时候,后访问的事务必须等前一个事务执行完成,才能继续执行。




