这里举一个简单的幻读的例子,事务A查询到表T有1,2,3条记录,然后事务B新插入的记录4,此时如果事务A对记录4进行更新,发现竟然可以更新成功,那么就让人产生幻觉的感觉,明明表只有1,2,3条记录,为啥记录4也可以更新成功?
| 隔离级别 | 脏读 | 不可重复读 | 幻读 |
|---|---|---|---|
| 读未提交(Read uncommitted) | 可能 | 可能 | 可能 |
| 读已提交(Read committed) | 不可能 | 可能 | 可能 |
| 可重复读(Repeatable read) | 不可能 | 不可能 | 可能 |
| 可串行化(Serializable) | 不可能 | 不可能 | 不可能 |
select @@tx_isolation;
select @@global.tx_isolation;
set session transaction isolation level repeatable read;
set global transaction isolation level repeatable read;
mysql的默认隔离级别是REPEATABLE-READ,也就是可重复读,这种情况下不可能产生脏读和不可重复读的问题。
./mysql -u root -p
这里输入密码,我的是123456,然后执行建表语句,我这里用的数据库是test,没有的话可以先建!
use test;CREATE TABLE IF NOT EXISTS `test`( `id` INT UNSIGNED AUTO_INCREMENT, `word` VARCHAR(100) NOT NULL, PRIMARY KEY ( `id` ))ENGINE=InnoDB DEFAULT CHARSET=utf8;INSERT INTO `test`(`word`)VALUES('A');INSERT INTO `test`(`word`)VALUES('B');INSERT INTO `test`(`word`)VALUES('C');SELECT * FROM `test`;
set session transaction isolation level read uncommitted;select @@tx_isolation;
我们可以看到隔离级别已经调为read uncommitted。我们知道,这个级别是可能会发生脏读、不可重复度、幻读的,我们这里只需要举一个脏读的例子即可,毕竟如果脏读都发生了,那么不可重复读和幻读必然可能发生。
用例如下:
1、事务A开启事务,查询test表
2、事务B开启事务,查询test表,后将id为1的记录修改为A1
3、此时事务B未提交,查看事务A能否读取到A1,若能读取,表明发生了脏读。
由例子可以知道,事务B未提交,但是事务A却已经读到了事务B修改的数据,所以发生了脏读。
set session transaction isolation level read committed;select @@tx_isolation;
我们可以看到隔离级别已经调为read committed。我们知道,这个级别是不可能会发生脏读,但是可能会发生不可重复度、幻读。那么我们重新按照上面的例子看看有没有发生脏读。
脏读用例如下:
1、事务A开启事务,查询test表
2、事务B开启事务,查询test表,后将id为1的记录修改为A2
3、此时事务B未提交,查看事务A能否读取到A2,若能读取,表明发生了脏读。
我们可以看到,当隔离级别调成读已提交(Read committed)后,脏读就没有发生了,但是此时我们事务B提交,然后A再读,结果如下:
我们看到,事务A也变化了,表明发生了不可重复读,事务A第一次和第二次读取的结果发生了变化。
set session transaction isolation level repeatable read;select @@tx_isolation;
我们可以看到隔离级别已经调为repeatable read;。我们知道,这个级别是不可能会发生脏读,和不可重复度,但是可能发生幻读。那么我们重新按照上面的例子看看有没有发生脏读和不可重复读。
不可重复读用例如下:
1、事务A开启事务,查询test表
2、事务B开启事务,查询test表,后将id为1的记录修改为A3
3、此时事务B未提交,查看事务A能否读取到A3,若不能读取,表明未发生脏读。
4、此时把事务B提交,查看事务A能否读取到A3,若还是不能,表明未发生不可重复读。
有结果可以知道,事务A读取的记录一直都是A2,就算事务B提交了也不会有影响,所以可重复读(Repeatable read)级别不可能会发生脏读和不可重复读。那可不可能发生幻读呢?
我们在事务B插入一条数据(4,D),然后提交。
INSERT INTO `test`(`word`)VALUES('D');
然后A也修改id未4的数据把D修改未D1,发现修改成功了,明明本来没有数据D的,现在突然就有了,好像出现了幻觉一样,所以这里发生了幻读。
set session transaction isolation level serializable;select @@tx_isolation;
我们可以看到隔离级别已经调为read committed。我们知道,这个级别是不可能会发生脏读、不可重复度和幻读。那么我们重新按照上面的例子看看有没有发生幻读。
幻读案例
1、事务A开启事务,查询test表
2、事务B插入一条数据(5,E)
INSERT INTO `test`(`word`)VALUES('E');
我们发现,事务B直接卡住了,所以不可能发生幻读。
我想为Heroku构建一个Rails3应用程序。他们使用Postgres作为他们的数据库,所以我通过MacPorts安装了postgres9.0。现在我需要一个postgresgem并且共识是出于性能原因你想要pggem。但是我对我得到的错误感到非常困惑当我尝试在rvm下通过geminstall安装pg时。我已经非常明确地指定了所有postgres目录的位置可以找到但仍然无法完成安装:$envARCHFLAGS='-archx86_64'geminstallpg--\--with-pg-config=/opt/local/var/db/postgresql90/defaultdb/po
尝试通过RVM将RubyGems升级到版本1.8.10并出现此错误:$rvmrubygemslatestRemovingoldRubygemsfiles...Installingrubygems-1.8.10forruby-1.9.2-p180...ERROR:Errorrunning'GEM_PATH="/Users/foo/.rvm/gems/ruby-1.9.2-p180:/Users/foo/.rvm/gems/ruby-1.9.2-p180@global:/Users/foo/.rvm/gems/ruby-1.9.2-p180:/Users/foo/.rvm/gems/rub
在MRIRuby中我可以这样做:deftransferinternal_server=self.init_serverpid=forkdointernal_server.runend#Maketheserverprocessrunindependently.Process.detach(pid)internal_client=self.init_client#Dootherstuffwithconnectingtointernal_server...internal_client.post('somedata')ensure#KillserverProcess.kill('KILL',
我的最终目标是安装当前版本的RubyonRails。我在OSXMountainLion上运行。到目前为止,这是我的过程:已安装的RVM$\curl-Lhttps://get.rvm.io|bash-sstable检查已知(我假设已批准)安装$rvmlistknown我看到当前的稳定版本可用[ruby-]2.0.0[-p247]输入命令安装$rvminstall2.0.0-p247注意:我也试过这些安装命令$rvminstallruby-2.0.0-p247$rvminstallruby=2.0.0-p247我很快就无处可去了。结果:$rvminstall2.0.0-p247Search
我发现ActiveRecord::Base.transaction在复杂方法中非常有效。我想知道是否可以在如下事务中从AWSS3上传/删除文件:S3Object.transactiondo#writeintofiles#raiseanexceptionend引发异常后,每个操作都应在S3上回滚。S3Object这可能吗?? 最佳答案 虽然S3API具有批量删除功能,但它不支持事务,因为每个删除操作都可以独立于其他操作成功/失败。该API不提供任何批量上传功能(通过PUT或POST),因此每个上传操作都是通过一个独立的API调用完成的
由于fast-stemmer的问题,我很难安装我想要的任何rubygem。我把我得到的错误放在下面。Buildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingfast-stemmer:ERROR:Failedtobuildgemnativeextension./System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/bin/rubyextconf.rbcreatingMakefilemake"DESTDIR="cleanmake"DESTDIR=
当我尝试安装Ruby时遇到此错误。我试过查看this和this但无济于事➜~brewinstallrubyWarning:YouareusingOSX10.12.Wedonotprovidesupportforthispre-releaseversion.Youmayencounterbuildfailuresorotherbreakages.Pleasecreatepull-requestsinsteadoffilingissues.==>Installingdependenciesforruby:readline,libyaml,makedepend==>Installingrub
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
我意识到这可能是一个非常基本的问题,但我现在已经花了几天时间回过头来解决这个问题,但出于某种原因,Google就是没有帮助我。(我认为部分问题在于我是一个初学者,我不知道该问什么......)我也看过O'Reilly的RubyCookbook和RailsAPI,但我仍然停留在这个问题上.我找到了一些关于多态关系的信息,但它似乎不是我需要的(尽管如果我错了请告诉我)。我正在尝试调整MichaelHartl'stutorial创建一个包含用户、文章和评论的博客应用程序(不使用脚手架)。我希望评论既属于用户又属于文章。我的主要问题是:我不知道如何将当前文章的ID放入评论Controller。
我有一个涉及多台机器、消息队列和事务的问题。因此,例如用户点击网页,点击将消息发送到另一台机器,该机器将付款添加到用户的帐户。每秒可能有数千次点击。事务的所有方面都应该是容错的。我以前从未遇到过这样的事情,但一些阅读表明这是一个众所周知的问题。所以我的问题。我假设安全的方法是使用两阶段提交,但协议(protocol)是阻塞的,所以我不会获得所需的性能,我是否正确?我通常写Ruby,但似乎Redis之类的数据库和Rescue、RabbitMQ等消息队列系统对我的帮助不大——即使我实现某种两阶段提交,如果Redis崩溃,数据也会丢失,因为它本质上只是内存。所有这些让我开始关注erlang和