设为首页 收藏本站
查看: 948|回复: 0

[经验分享] MySQL事务和隔离级别

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-9-6 09:00:03 | 显示全部楼层 |阅读模式
MySQL事务和隔离级别

连接管理器:
        接受请求
        创建线程
        认证用户
        建立安全连接
       
并发控制:
        最简单机制是使用锁
                        多版本并发控制: MVCC(使用其他机制)


锁:
        读锁:共享锁
        写锁:独占锁
        加锁:        LOCK TABLES tb_name {READ|WRITE};
        解锁:        UNLOCK TABLES       
               
锁粒度:从大到小,MySQL服务器仅支持表级锁,行锁需要由存储引擎完成;
        表锁:
        页锁:
        行锁:

事务:
        RDBMS: ACID (原子性,一致性,隔离性,持久性)
       
        MyISAM:不支持事务
        InnoDB:支持事务

事务日志:为事务提供ACID兼容性(日志中只是记录操作过程)
                重做日志
                        redo log
                撤销日志
                        undo log
       
隔离性:
        隔离级别:
                READ UNCOMMITTED:读未提交
                READ COMMITTED:读提交
                REPATABLE READ:可重读
                SERIABLIZABLE:可串行       
查询默认隔离级别:
show global variables like '%iso%';       

多事务同时执行:彼此之间互不影响的方式进行并行;
        事务之间交互:
                通过数据集

事务:CPU, I/O
        RDBMS,
                ACID:
                        Automicity:原子性,事务所引起的数据库操作,要么都完成,要么都不执行;
                        Consistency:一致性,A(3000)-->B(2000)
                                1:A:3000-->2500,
                                2: A+B: 4500,
                        Isolation: 隔离性
                                事务调度:事务之间影响最小
                                MVCC:多版本并发控制
                        Durability:一旦事务成功完成,系统必须保证任何故障都不会引起事务表示出不一致性;
                                1、事务提交之前就已经写出数据至持久性存储;
                                2、结合事务日志完成;
                                        事务日志:顺序IO
                                        数据文件:随机IO

        事务的状态:
                活动的:active
                部分提交的:最后一条语句执行后
                失败的:
                中止的:
                提交的:
事务一旦提交就不能撤销

事务:并发执行
        1、提高吞吐量和资源利用率
        2、减少等待时间

事务调度:
        可恢复调度;
        无级联高度:
       
并发控制依赖的技术手段:
        锁
        时间戳
        多版本和快照隔离       
       
START TRANSACTION | BEGIN:启动事务
        SQL
        SQL
COMMIT: 提交
ROLLBACK: 回滚       


如果没有明确启动事务:
        autocommit:能实现自动提交,每一个操作都直接提交;

        建议:明确使用事务,并且关闭自动提交;
       
保存点:SAVEPOINT sid
回滚至保存点:ROLLBACK TO sid        



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-268295-1-1.html 上篇帖子: MySQL管理表和索引 下篇帖子: mysql host privileges 隔离
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表