WEB开发网
开发学院数据库MySQL Mysql入门系列:MySQL不支持的功能 阅读

Mysql入门系列:MySQL不支持的功能

 2006-12-31 10:46:16 来源:WEB开发网   
核心提示: t1销售人员1卖出3件衬衫t2 销售人员检索当前衬衫计数( 4 7):SELECT quantity FROM inventory WHERE item = "shirt"t3 销售人员2卖出2件衬衫t4 销售人员2检索当前衬衫计数( 4 7)SELECT quanti

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"

上一页  1 2 3 4 5 6  下一页

Tags:Mysql 入门 系列

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接