预览加载中,请您耐心等待几秒...
1/4
2/4
3/4
4/4

在线预览结束,喜欢就下载吧,查找使用更方便

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

Mysql入门系列:MySQL不支持的功能 3.9MySQL不支持的功能 本节介绍其他数据库中有而MySQL中无的功能。它介绍省略了什么功能,以及在需要这些功能时怎么办。一般情况下,MySQL之所以忽略某些功能是因为它们有负面性能影响。有的功能正在开发者的计划清单上,一旦找到一种方法可以实现相应的功能而又不致于影响 良好性能的目标,就会对它们进行实现。 ■子选择。子选择是嵌套在另一个SELECT语句内的SELECT语句,如下面的查询所示: SELECT*FROMscore WHEREevent_idIN(SELECTevent_idFROMeventWHEREtype="T") 子选择打算在MySQL3.24中给出,到那时它们就不会忽略了。但到那时,许多用子选择撰写的查询也可以用连接来编写。请参阅3.8.1节“将子选择编写为连接”。 ■事务处理和提交/回退。事务处理是由其他客户机作为一个整体不中断执行的一组SQL语句。提交/回退功能允许规定数条语句作为一个整体执行或不执行。即,如果事务处理中的任何一条语句失败,那么直到该语句前执行的所有语句的作用都被撤消。 ySQL自动进行单一SQL语句的同步以免客户机互相干扰。(例如,两个客户机不能对相同的表进行同时写入。)此外,可利用LOCKTABLES和UNLOCKTABLES将数条语句组成一个整体,这使您能够完成单条语句的并发控制所不能满足的操作。MySQL与事务处理有关的问题是,它不能自动对数条语句进行组织,而且如果这些语句中有某一条失败后也不能对它们进行回退。 为了弄清事务处理为什么有用,可举例说明。假如您在服装销售业工作,无论何时,只要您的销售人员进行了一次销售,都要更新库存数目。下面的例子说明了在多个销售人员同时更新数据库时可能出现的问题(假如初始的衬衫库存数目为47): t1销售人员1卖出3件衬衫 t2销售人员检索当前衬衫计数(47): SELECTquantityFROMinventoryWHEREitem="shirt" t3销售人员2卖出2件衬衫 t4销售人员2检索当前衬衫计数(47) SELECTquantityFROMinventoryWHEREitem="shirt" t5销售人员1计算库存的新数目为47-3=44并设置衬衫计数为44: UPDATEinventorySETquantity=44WHEREitem="shirt" t6销售人员2计算库存的新数目为47-2=45并设置衬衫计数为45: UPDATEinventorySETquantity=45WHEREitem="shirt" 在这个事件序列结束时,您已经卖掉了5件衬衫,但库存数目却是45而不是42。问题是如果在一条语句中查看库存而在另一条语句中更新其值,这是一个多语句的事务处理。第二条语句中所进行的活动取决于第一条语句中检索出的值。但是如果在重叠的时间范围内出现独立的事务处理,则每个事务处理的语句会纠缠在一起,并且互相干扰。在事务处理型的数据库中,每个销售人员的语句可作为一个事务处理执行,这样,销售人员2的语句在销售人员1的语句完成之前不会被执行。在MySQL中,可用两种方法达到这个目的: ■方法1:作为一个整体执行一组语句。可利用LOCKTABLES和UNLOCKTABLES将语句组织在一起,并将它们作为一个原子单元执行:锁住所需使用的表,发布查询,然后释放这些锁。这样阻止了其他人在您锁住这些表时使用它们。利用表同步,库存情况如下所示: t1销售人员1卖出3件衬衫 t2销售人员1请求一个锁并检索当前衬衫计数(47) LOCKTABLESinventoryWRITE SELECTquantityFROMinventoryWHEREitem="shirt" >t3销售人员2卖出2件衬衫 t4销售人员2试图取得一个锁:这被阻塞,因为销售人员1已经占住了锁: LOCKTABLESinventoryWRITE t5销售人员1计算库存的新数目为47-3=44并设置衬衫计数为44,然后释放锁: UPDATEinventorySETquantity=44WHEREitem="shirt" UNLOCKTABLES t6现在销售人员2的锁请求成功。销售人员2检索当前衬衫计数(44) SELECTquantityFROMinventoryWHEREitem="shirt" t7销售人员2计算库存的新数目为44-2=42,设置衬衫计数为42,然后释放锁: UPDATEinventorySETquantity=42WHEREitem="shirt" UNLOCKTABLES 现在来自两个事务处理的语句不混淆了,并且库存衬衫数也正确进行了设置。我们在这里使用了一个WRITE锁,因为我们需要修改inventory表。如