`
majie
  • 浏览: 74988 次
  • 来自: ...
社区版块
存档分类
最新评论

mysql 事务处理例析

阅读更多

      事务处理和提交/回退。事务处理是由其他客户机作为一个整体不中断执行的一组SQL语句。提交/回退功能允许规定数条语句作为一个整体执行或不执行。即,如果事务处理中的任何一条语句失败,那么直到该语句前执行的所有语句的作用都被撤消。

    为了弄清事务处理为什么有用,可举例说明。假如您在服装销售业工作,无论何时,只要您的销售人员进行了一次销售,都要更新库存数目。下面的例子说明了在多个销售人员同时更新数据库时可能出现的问题(假如初始的衬衫库存数目为4 7):
    t1销售人员1卖出3件衬衫
    t2 销售人员检索当前衬衫计数( 4 7):
    SELECT quantity FROM inventory WHERE item = "shirt"
    t3 销售人员2卖出2件衬衫
    t4 销售人员2检索当前衬衫计数( 4 7)
    SELECT quantity FROM inventory WHERE item = "shirt"
    t5 销售人员1计算库存的新数目为47 - 3 = 44 并设置衬衫计数为44:
    UPDATE inventory SET quantity = 44 WHERE item = "shirt"
    t6 销售人员2计算库存的新数目为47 - 2 = 45 并设置衬衫计数为45:
    UPDATE inventory SET quantity = 45 WHERE item = "shirt"
    在这个事件序列结束时,您已经卖掉了5 件衬衫,但库存数目却是45 而不是4 2。问题是如果在一条语句中查看库存而在另一条语句中更新其值,这是一个多语句的事务处理。第二条语句中所进行的活动取决于第一条语句中检索出的值。但是如果在重叠的时间范围内出现独立的事务处理,则每个事务处理的语句会纠缠在一起,并且互相干扰。在事务处理型的数据库中,每个销售人员的语句可作为一个事务处理执行,这样,销售人员2 的语句在销售人员1的语句完成之前不会被执行。在MySQL中,可用两种方法达到这个目的:

方法1:作为一个整体执行一组语句。可利用LOCK TABLES 和UNLOCK TABLES将语句组织在一起,并将它们作为一个原子单元执行:锁住所需使用的表,发布查询,然后释放这些锁。这样阻止了其他人在您锁住这些表时使用它们。利用表同步,库存情况如下所示:
    t1销售人员1卖出3件衬衫
    t2 销售人员1请求一个锁并检索当前衬衫计数(47)
    LOCK TABLES inventory WRITE
    SELECT quantity FROM inventory WHERE item = "shirt"
    t3 销售人员2卖出2件衬衫
    t4 销售人员2试图取得一个锁:这被阻塞,因为销售人员1已经占住了锁:
    LOCK TABLES inventory WRITE
    t5 销售人员1计算库存的新数目为47 - 3 = 44 并设置衬衫计数为44,然后释放锁:
    UPDATE inventory SET quantity = 44 WHERE item = "shirt"
UNLOCK TABLES
    t6 现在销售人员2的锁请求成功。销售人员2检索当前衬衫计数( 44)
    SELECT quantity FROM inventory WHERE item = "shirt"
    t7 销售人员2计算库存的新数目为44 - 2 = 42,设置衬衫计数为4 2,然后释放锁:
    UPDATE inventory SET quantity = 42 WHERE item = "shirt"
    UNLOCK TABLES
    现在来自两个事务处理的语句不混淆了,并且库存衬衫数也正确进行了设置。我们在这里使用了一个WRITE 锁,因为我们需要修改inventory 表。如果只是读取表,可使用READ 锁。当您正在使用表时,这个锁允许其他客户机读取表。在刚才举的例子中,销售人员2大概不会注意到执行速度上的差异,因为其中的事务处理都很短,执行速度很快。但是,作为一个具有普遍意义的规则,那就是应该尽量避免长时间地锁住表。
    如果您正在使用多个表,那么在您执行成组查询之前,必须锁住他们。如果只是从某个特定的表中读取数据,那么只需给该表加一个读出锁而不是写入锁。假如有一组查询,其中想对inventory 表作某些更改,而同时需要从customer 表中读取某些数据。在此情形下,inventory 表上需要一个写入锁,而customer 表上需要一个读出锁:
    LOCK TABLES inventory WRITE,customer READ
    ...
    UNLOCK TABLES
    这里要求您自己对表进行加锁和解锁。支持事务处理的数据库系统将会自动完成这些工作。但是,在作为一个整体执行的分组语句方面,无论在是否支持事务处理的数据库中都是相同的。

方法2:使用相对更新而不是绝对更新。要解决来自多个事务处理的语句混淆问题,应消除语句之间的依赖性。虽然这样做并不都总是可能的,它只针对我们的库存例子可行。对于方法1中所用的库存更新方法,其中事务处理需要查看当前库存数目,并依据销售衬衫的数目计算新值,然后更新衬衫的数目。有可能通过相对于当前衬衫数目进行计数更新,在一个步骤中完成工作。如下所示:

t1销售人员1卖出3件衬衫
    t2 销售人员1将衬衫计数减3:
    UPDATE inventory SET quantity = quantity - 3 WHERE item = "shirt"
    t3 销售人员2卖出2件衬衫
    t4 销售人员2将衬衫计数减2:
    UPDATE inventory SET quantity = quantity - 2 WHERE item = "shirt"
    因此,这里根本不需要多条语句的事务处理,从而也不需要锁住表以模拟事务处理功能。

个人觉得第一种方法好.当然还有其他很多种方法可解决类似的问题,如把业务逻辑写在程序中,从而避开数据库承载过多的业务逻辑.


分享到:
评论

相关推荐

    mySQL事务处理

    关于mysql的事务处理 public static void StartTransaction(Connection con, String[] sqls) throws Exception { if (sqls == null) { return; } Statement sm = null; try { // 事务开始 System....

    nodejs + mysql 事务处理问题

    nodejs + mysql 事物处理问题 呵呵 看了就知道 记得npm install啊 需要的东西啊 本想免费 苦于没积分 ,需要的的同学,给点分吧

    mysql事务处理用法与实例详解

    ### MySQL事务处理用法与实例详解 #### 一、事务的概念及重要性 在数据库管理中,事务(Transaction)是指一系列作为一个整体的操作序列。这些操作要么全部成功,要么全部失败,不能只执行其中的一部分。事务处理...

    Java实现的mysql事务处理操作示例

    "Java实现的mysql事务处理操作示例" 本文主要介绍了Java实现的mysql事务处理操作,结合实例形式较为详细的分析了Java基于JDBC操作mysql数据库实现事务处理的相关概念、操作技巧与注意事项。 事务处理是数据库操作...

    MySql事务处理.docx

    MySQL 事务处理是数据库管理系统中的关键特性,主要用于确保数据操作的安全性和一致性。在MySQL中,事务主要应用于支持事务的存储引擎,如InnoDB或BDB。这些存储引擎能够提供事务的四大特性:原子性(Atomicity)、...

    MySql事务处理.pdf

    MySQL中的事务处理是数据库管理的重要组成部分,主要目的是确保数据的一致性和完整性。事务是一组SQL语句,它们作为一个单元执行,要么全部成功,要么全部回滚,这确保了原子性。事务处理的引入是为了解决多用户、多...

    mysql 事务处理学习资料+示例说明

    根据提供的文件信息,本文将详细解释MySQL事务处理的相关知识点,并结合具体的示例代码进行说明。 ### MySQL事务处理基础 在数据库操作中,事务处理是非常重要的一个环节,它能够确保数据的一致性和完整性。MySQL...

    深入剖析Oracle与MySQL在事务处理上的差异

    本文将从事务的基本概念、隔离级别、锁机制以及事务控制语句等方面,详细探讨Oracle与MySQL在事务处理上的差异,并提供代码示例。 Oracle和MySQL在事务处理上有着各自的特点。Oracle提供了强大的并发控制和隔离级别...

    MySQL事务处理详细讲解及完整实例

    MySQL事务是数据库操作的核心概念,尤其在处理并发和数据一致性时显得尤为重要。事务是一组数据库操作,这些操作被视为一个逻辑工作单元,只有当所有操作都成功执行时,事务才会被提交;如果有任何错误,整个事务将...

    MySQL或Oracle通过ODBC与C#建立连接和进行事务处理

    ### MySQL或Oracle通过ODBC与C#建立连接和进行事务处理 #### 一、概述 在现代企业级应用开发中,数据库的选择对于整个系统的稳定性和性能有着至关重要的影响。随着多语言开发的需求日益增长,如何让不同的编程语言...

    mysql事务处理[归类].pdf

    MySQL的事务处理是数据库管理中的核心功能,尤其在软件开发中,确保数据一致性、安全性和可靠性至关重要。事务处理允许数据库操作作为一个不可分割的整体执行,确保数据的完整性和一致性。在人员管理系统等应用中,...

    MySQL事务隔离级别

    MySQL事务隔离级别是数据库管理系统中一个非常重要的概念,它关系到数据的一致性和并发性能。在MySQL中,事务被用于确保数据库操作的原子性、一致性、隔离性和持久性(ACID特性)。事务隔离级别主要涉及四个方面:读...

    php实现mysql事务处理的方法

    本文实例讲述了php实现mysql事务处理的方法。分享给大家供大家参考。具体分析如下: 要实现本功能的条件是环境 mysql 5.2 /php 5 支持事务的table 类型,需要InnoDB,有了这些条件你就可以做上面的实现了,这个事物回滚...

    mysql事务学习资料(PPT+源码)

    在这个"mysql事务学习资料(PPT+源码)"中,你将深入理解MySQL事务的概念、类型、特性和实际应用。 1. **事务概念**:在数据库中,事务是一系列操作的集合,这些操作要么全部成功,要么全部回滚,以保持数据的一致性...

    Mysql事务处理详解

    MySQL事务处理详解主要涵盖事务的基本概念、特性以及事务隔离级别,这些都是数据库管理中至关重要的概念。MySQL中的事务主要用于处理大量且复杂的操作,确保数据的一致性和完整性。 首先,事务是MySQL数据库操作的...

    MySQL事务处理与并发访问.pdf

    MySQL事务处理与并发访问.pdf

    mysql分布式事务实现 MySQL XA pdf

    ### MySQL分布式事务处理与XA协议详解 #### 一、引言 在当今互联网技术高度发展的背景下,分布式系统已经成为处理大规模数据的关键技术之一。而在分布式环境中,确保数据的一致性成为了非常重要的挑战。其中,...

    MySQL与事务

    ### MySQL与事务处理详解 #### 一、引言 MySQL作为一种广泛使用的开源关系型数据库管理系统,在数据管理和存储方面发挥着重要作用。尽管MySQL5.x已经发布了很长时间,但仍有一些人错误地认为MySQL不支持事务处理...

Global site tag (gtag.js) - Google Analytics