zoukankan      html  css  js  c++  java
  • 什么是事务?

    • 事务的概念
      • 含义:事务由单独单元的一个或者多个sql语句组成,在这个单元中,每个mysql语句时相互依赖的。而整个单独单元作为一个不可分割的整体,如果单元中某条sql语句一旦执行失败或者产生错误,整个单元将会回滚,所有受到影响的数据将会返回到事务开始以前的状态;如果单元中的所有sql语句均执行成功,则事务被顺利执行。
      • 事务的属性
        • 原子性:一个事务不可在分割,要么都执行要么都不执行。
        • 一致性:一个事务的执行会使数据从一个一致状态切换到另一个一致的状态。
        • 隔离性:一个事务的执行不受其他事物的干扰
        • 持久性: 一个事务一旦提交,则会永久的改变数据库的数据
      • 事务的创建
        • 隐式事务:事务没有明显的开启和结束的标记
        • 显式事务:事务具有明显的开启和结束的标记 前提:必须先设置自动提交功能为禁用
        步骤1:开启事务
            set autocommit=0;
            start transaction;可选的
        步骤2:编写事务中的sql语句(select insert update delete)
              语句1
              语句2
        步骤3:结束事务
            commit;提交事务
            rollback;回滚事务
        
      • 数据库的隔离级别
        • 对于同时运行的多个事务,当这些事务访问数据库中的相同的数据时,如果没有采取必要的隔离机制就会产生并发问题: 脏读,不可重复读,幻读。
        • 数据库事务的隔离性:数据库系统必须具有隔离并发运行各个事务的能力,使他们不会相互影响避免并发问题。
        • 一个事物与其他事务隔离的程度称为隔离级别。隔离级别越高,,数据一致性就越好,但并发性就越弱。
        ```
        //mysql隔离级别查询
        select @@tx_isolation;
        ```
        
  • 相关阅读:
    spring.net 结合简单三层实例
    Spring.Net 如何管理您的类___对象的手动装配
    性能优化小结
    C#实例解析适配器设计模式
    谈AOP要step by step
    C#对图片文件的压缩、裁剪操作初探
    Web 前端开发精华文章推荐(jQuery、HTML5、CSS3)
    多线程实现资源共享的问题学习与总结
    ASP.NET 设计模式
    Mac技巧索引
  • 原文地址:https://www.cnblogs.com/narojay/p/10812618.html
Copyright © 2011-2022 走看看