热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

数据库事务轻松走进数据库系列之十-mysql教程

事务的概念:SQL语句中一个执行单元,由一系列的sql语句组成。事务中的操作语句可作为一个不可分割的整体,要么全部执行,要么全部不执行。事务好比把一系列的相关的SQL语句捆绑在一起,一起执行,执行失败还可以人性化的回滚到操作之前,或者回滚到你

事务的概念 :SQL 语句中一个执行单元,由一系列的 sql 语句组成。事务中的操作语句可作为一个不可分割的整体,要么全部执行,要么全部不执行。 事务好比把一系列的相关的SQL 语句捆绑在一起,一起执行,执行失败还可以人性化的回滚到操作之前,或者回滚到你

事务的概念:SQL 语句中一个执行单元,由一系列的sql语句组成。事务中的操作语句可作为一个不可分割的整体,要么全部执行,要么全部不执行。事务好比把一系列的相关的SQL 语句捆绑在一起,一起执行,执行失败还可以人性化的回滚到操作之前,或者回滚到你设置的保存点处。引入事务,使我们对数据库操作更加简单,且保证 了数据库的数据完整性。

在这个封装好的事务中,有完善的机能。

事务的分类:隐性事务,显式事务,自动提交事务。

各种事物的区分:

显式事务:有明显的sql语句标识:begin transaction开始和committransaction或者rollback transaction结束。

隐性事务(complicit transaction):1、在setimplicit_transaction on 语句之后进入隐性事务模式。

2、启动语句: altertableopendroptruncate tableinsertdeleteselectcreategrantrevokefetchupdate。首次执行上述语句后,自动进入隐性事务,知道出现结束事务语句。

自动提交事务:一个sql语句完成都算是一个自动提交事务。成功完成,则提交成功,没有成功执行sql语句,则回滚该语句。这就是自动提交事务的功能。

注意:一般有明显的标志语句就是显示事务,其次是一些隐式事务的启动语句,暗示着隐式事务,在没有显式事务和隐性事务的时候才是发生自动提交事务。

事务的主要作用避免数据的不一致。(触发器)

事务定义的语


为了更详细的了解事务是一系列SQL 语句的组成,我们再来看一个事务的简单例子。这个例子中,我们在部门表中把后勤部删除,同时也从员工表中把属于后勤部的员工给删除了,这是两天SQL 语句组成的事务,因为是一连串事件,所以封装在一个事务中,一起执行,这样就保证了数据的完整性,一致性。



事务回滚


事务在执行中,并不是每次都可以成功,由于一些原因,执行不成功,那么就是这个事务无法提交,为了保证数据的完整性,我们要执行事务回滚。打个比方,大家都在淘宝买东西,我们选好颜色,款式,数量后,提交订单,这就是一个事务,你的购物在店主那里都有记录,这就是一个事务,如果,你在操作过程中出现问题了,网页断开,或是停电,无法提交,那么你之前进行的操作也就不会保存,再次登入的时候,这些信息还需要填写。这就是事务回滚,他会自动回滚到操作之前。

语法:rollback transaction transaction_name|savepointname

其中,transaction_name是回滚到事务操作之前。

savepointname 是回滚到特点的位置,叫做保存点,保存点需要手动设置。

设置保存点

save transaction savepointname


在整个事务中,顺序是很重要的,先执行什么,后执行什么。保存点设置就是如此,在执行完那步之后设置保存点,那么事务就会回滚到设置保存点之前的那个操作。

最后让我们来看一个完整的例子,有事务封装,有保存点的设置,这个事务提交失败后,会回滚到删除完后勤部的位置。

一下事务的完整操作:

分布式事务(distributed transaction

前边讲的事务是处理一个服务器的数据,涉及到多个服务器的时候用到一类新的事物——分布式事务。

使用分布式服务器需要首先启动MSDTC服务。

执行时将begin transaction换成begin distributed transaction即可。



推荐阅读
  • 本文详细介绍了在 Windows 7 上安装和配置 PHP 5.4 的 Memcached 分布式缓存系统的方法,旨在减少数据库的频繁访问,提高应用程序的响应速度。 ... [详细]
  • 深入浅出:Hadoop架构详解
    Hadoop作为大数据处理的核心技术,包含了一系列组件如HDFS(分布式文件系统)、YARN(资源管理框架)和MapReduce(并行计算模型)。本文将通过实例解析Hadoop的工作原理及其优势。 ... [详细]
  • 帝国cms各数据表有什么用
    CMS教程|帝国CMS帝国cmsCMS教程-帝国CMS精易编程助手源码,ubuntu桥接设置,500错误是tomcat吗,爬虫c原理,php会话包括什么,营销seo关键词优化一般多 ... [详细]
  • 时序数据是指按时间顺序排列的数据集。通过时间轴上的数据点连接,可以构建多维度报表,揭示数据的趋势、规律及异常情况。 ... [详细]
  • 本文介绍了多种Eclipse插件,包括XML Schema Infoset Model (XSD)、Graphical Editing Framework (GEF)、Eclipse Modeling Framework (EMF)等,涵盖了从Web开发到图形界面编辑的多个方面。 ... [详细]
  • 集群与负载均衡技术解析
    本文探讨了集群(Cluster)的概念,即通过网络连接的一组计算机系统,它们作为一个整体提供服务,实现分布式计算。文章还详细介绍了负载均衡技术,旨在提高网络服务的效率和可靠性。 ... [详细]
  • 本书《Pro Git》深入探讨了 Git 版本控制系统的核心概念与高级功能,旨在帮助开发者和团队有效管理代码变更。通过实例和最佳实践,读者将学习如何利用 Git 提升工作效率。 ... [详细]
  • 尤洋:夸父AI系统——大规模并行训练的深度学习解决方案
    自从AlexNet等模型在计算机视觉领域取得突破以来,深度学习技术迅速发展。近年来,随着BERT等大型模型的广泛应用,AI模型的规模持续扩大,对硬件提出了更高的要求。本文介绍了新加坡国立大学尤洋教授团队开发的夸父AI系统,旨在解决大规模模型训练中的并行计算挑战。 ... [详细]
  • RabbitMQ 核心组件解析
    本文详细介绍了RabbitMQ的核心概念,包括其基本原理、应用场景及关键组件,如消息、生产者、消费者、信道、交换机、路由键和虚拟主机等。 ... [详细]
  • 本文探讨了在SharePoint环境中使用BDC(Business Data Catalog)时遇到的问题及其解决策略,包括XML文件导入SSP后的不可见性问题以及与远程SQL Server 2005连接的难题。 ... [详细]
  • Git版本控制基础解析
    本文探讨了Git作为版本控制工具的基本概念及其重要性,不仅限于代码管理,还包括文件的历史记录与版本切换功能。通过对比Git与SVN,进一步阐述了分布式版本控制系统的独特优势。 ... [详细]
  • 本文详细介绍了PHP中的几种超全局变量,包括$GLOBAL、$_SERVER、$_POST、$_GET等,并探讨了AJAX的工作原理及其优缺点。通过具体示例,帮助读者更好地理解和应用这些技术。 ... [详细]
  • 初探Hadoop:第一章概览
    本文深入探讨了《Hadoop》第一章的内容,重点介绍了Hadoop的基本概念及其如何解决大数据处理中的关键挑战。 ... [详细]
  • 本文详细介绍了如何在PHP中使用Memcached进行数据缓存,包括服务器连接、数据操作、高级功能等。 ... [详细]
  • 本文探讨了使用Python实现监控信息收集的方法,涵盖从基础的日志记录到复杂的系统运维解决方案,旨在帮助开发者和运维人员提升工作效率。 ... [详细]
author-avatar
夕阳红梅乎
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有