Inhaltsverzeichnis
回复内容:
Heim Backend-Entwicklung PHP-Tutorial 我想测试InnoDB的行锁怎么测试不了呢?帮忙看下我的代码没错吧?

我想测试InnoDB的行锁怎么测试不了呢?帮忙看下我的代码没错吧?

Jun 06, 2016 pm 08:23 PM
innodb mysql php thinkphp

<code>$u = M('r.goods');
$u-&gt;startTrans();
$arr = $u-&gt;lock(true)-&gt;select(8);
……</code>
Nach dem Login kopieren
Nach dem Login kopieren

注意我没有提交事务哦

现在的问题是:我要怎么来测试锁定呢?

网上说:“要测试锁定的状况,可以利用MySQL 的Command Mode ,开二个视窗来做测试。”

我开了两个命令行窗口A和B,A窗口开启事务,然后sql加锁查询,B窗口不进行任何操作,直接执行同样的加锁查询,感受到了这个“锁定等待”的状态,没有任何问题。

但是为什么我上面写的代码同样的没有提交事务,为什么刷新两次页面没有“锁住,页面卡主”的感觉啊,难道是php脚本执行完后,所开启的事务“自动失效”,还是什么情况呢,还是我写的代码有问题,怎么测试不出来跟命令行窗口中相同的效果呢?

还有一个疑问,我上面B窗口并没有开启事务,只是执行加锁查询,这样也会受影响吗?难道是加锁需要在事务区块中才能生效,而其他的查询时不一定要在事务中是吧,只要是带加锁查询的sql语句才会受上一个事务的影响是吧。

那为何我写的代码测试不出来这个效果呢?

回复内容:

<code>$u = M('r.goods');
$u-&gt;startTrans();
$arr = $u-&gt;lock(true)-&gt;select(8);
……</code>
Nach dem Login kopieren
Nach dem Login kopieren

注意我没有提交事务哦

现在的问题是:我要怎么来测试锁定呢?

网上说:“要测试锁定的状况,可以利用MySQL 的Command Mode ,开二个视窗来做测试。”

我开了两个命令行窗口A和B,A窗口开启事务,然后sql加锁查询,B窗口不进行任何操作,直接执行同样的加锁查询,感受到了这个“锁定等待”的状态,没有任何问题。

但是为什么我上面写的代码同样的没有提交事务,为什么刷新两次页面没有“锁住,页面卡主”的感觉啊,难道是php脚本执行完后,所开启的事务“自动失效”,还是什么情况呢,还是我写的代码有问题,怎么测试不出来跟命令行窗口中相同的效果呢?

还有一个疑问,我上面B窗口并没有开启事务,只是执行加锁查询,这样也会受影响吗?难道是加锁需要在事务区块中才能生效,而其他的查询时不一定要在事务中是吧,只要是带加锁查询的sql语句才会受上一个事务的影响是吧。

那为何我写的代码测试不出来这个效果呢?

大神在哪里,大神在哪里?,帮忙看下啊,为什么我自己打开多个页面测试不出来锁的效果呢?

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

PHP 8.4 Installations- und Upgrade-Anleitung für Ubuntu und Debian PHP 8.4 Installations- und Upgrade-Anleitung für Ubuntu und Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 Installations- und Upgrade-Anleitung für Ubuntu und Debian

CakePHP Datum und Uhrzeit CakePHP Datum und Uhrzeit Sep 10, 2024 pm 05:27 PM

CakePHP Datum und Uhrzeit

CakePHP-Projektkonfiguration CakePHP-Projektkonfiguration Sep 10, 2024 pm 05:25 PM

CakePHP-Projektkonfiguration

CakePHP-Datei hochladen CakePHP-Datei hochladen Sep 10, 2024 pm 05:27 PM

CakePHP-Datei hochladen

CakePHP-Routing CakePHP-Routing Sep 10, 2024 pm 05:25 PM

CakePHP-Routing

Besprechen Sie CakePHP Besprechen Sie CakePHP Sep 10, 2024 pm 05:28 PM

Besprechen Sie CakePHP

So beheben Sie den Fehler „mysql_native_password nicht geladen' unter MySQL 8.4 So beheben Sie den Fehler „mysql_native_password nicht geladen' unter MySQL 8.4 Dec 09, 2024 am 11:42 AM

So beheben Sie den Fehler „mysql_native_password nicht geladen' unter MySQL 8.4

CakePHP-Kurzanleitung CakePHP-Kurzanleitung Sep 10, 2024 pm 05:27 PM

CakePHP-Kurzanleitung

See all articles