ホームページ  >  記事  >  バックエンド開発  >  thinkphp トランザクション ロールバック処理と元の PHP トランザクション ロールバックの例

thinkphp トランザクション ロールバック処理と元の PHP トランザクション ロールバックの例

WBOY
WBOYオリジナル
2016-06-13 12:17:31966ブラウズ

Thinkphp トランザクション ロールバック処理と元の PHP トランザクション ロールバックの例

1. プログラムでトランザクションをサポートするには、まず接続されたデータベースとデータ テーブルがトランザクション mysql をサポートする必要があります。例:

データベース InnoDB トランザクションをサポートします。

データ テーブルはトランザクションをサポートします: InnoDB はトランザクションをサポートします

2. フレームワーク thinkphp トランザクションをサポートしますコード

<span style="color: #0000ff;">public</span> <span style="color: #0000ff;">function</span><span style="color: #000000;"> testrollback(){</span><span style="color: #800080;">$model1</span> = D('item'<span style="color: #000000;">);</span><span style="color: #800080;">$model2</span> = D('vote'<span style="color: #000000;">);</span><span style="color: #800080;">$model1</span>-><span style="color: #000000;">startTrans();</span><span style="color: #800080;">$res1</span> = <span style="color: #800080;">$model1</span>->where('id = 5')-><span style="color: #000000;">delete();</span><span style="color: #800080;">$res2</span> = <span style="color: #800080;">$model2</span>->where('id = 2')-><span style="color: #000000;">delete();dump(</span><span style="color: #800080;">$res1</span><span style="color: #000000;">);dump(</span><span style="color: #800080;">$res2</span><span style="color: #000000;">);</span><span style="color: #0000ff;">if</span>(<span style="color: #800080;">$res1</span> && <span style="color: #800080;">$res2</span><span style="color: #000000;">){</span><span style="color: #800080;">$model1</span>->commit();   <span style="color: #008000;">//</span><span style="color: #008000;">只有$res1 和  $res2  都执行成功是才真正执行上面的数据库操作</span>dump("commit"<span style="color: #000000;">);}</span><span style="color: #0000ff;">else</span><span style="color: #000000;">{</span><span style="color: #800080;">$model1</span>->rollback();  <span style="color: #008000;">//</span><span style="color: #008000;">  条件不满足,回滚</span>dump("rollback"<span style="color: #000000;">);}dump(</span>"over"<span style="color: #000000;">);</span><span style="color: #0000ff;">exit</span><span style="color: #000000;">;}</span>

3. 元の PHP コード トランザクション インスタンス

メソッド 1:データベースとデータ テーブルが両方とも innoDB

<span style="color: #0000ff;">public</span> <span style="color: #0000ff;">function</span><span style="color: #000000;">  rollbackoriginal1(){        </span><span style="color: #800080;">$conn</span> = <span style="color: #008080;">mysql_connect</span>('127.0.0.1','summerzi','summerzi') or <span style="color: #0000ff;">die</span>('DB connection failed!'<span style="color: #000000;">);        </span><span style="color: #008080;">mysql_select_db</span>('summer',<span style="color: #800080;">$conn</span><span style="color: #000000;">);        </span><span style="color: #008080;">mysql_query</span>('set names "GBK"'<span style="color: #000000;">);        </span><span style="color: #008080;">mysql_query</span>('BEGIN'<span style="color: #000000;">);        </span><span style="color: #800080;">$sql1</span> = "INSERT INTO `summer_userdata`(`uid`,`type`,`target_id`) VALUES(41,1,233);"<span style="color: #000000;">;        </span><span style="color: #800080;">$sql2</span> = "INSERT INTO `summer_userdata`(`uid`,`type`,`target_id`) VALUES(fdfd,2,235);"<span style="color: #000000;">;        </span><span style="color: #800080;">$res1</span> = <span style="color: #008080;">mysql_query</span>(<span style="color: #800080;">$sql1</span><span style="color: #000000;">);        </span><span style="color: #800080;">$res2</span>  = <span style="color: #008080;">mysql_query</span>(<span style="color: #800080;">$sql2</span><span style="color: #000000;">);        dump(</span><span style="color: #800080;">$sql1</span><span style="color: #000000;">);        dump(</span><span style="color: #800080;">$sql2</span><span style="color: #000000;">);        dump(</span><span style="color: #800080;">$res1</span><span style="color: #000000;">);        dump(</span><span style="color: #800080;">$res2</span><span style="color: #000000;">);        </span><span style="color: #0000ff;">if</span>(<span style="color: #800080;">$res1</span> && <span style="color: #800080;">$res2</span><span style="color: #000000;">){            </span><span style="color: #008080;">mysql_query</span>('COMMIT'<span style="color: #000000;">);            dump(</span>'commit success!'<span style="color: #000000;">);        }</span><span style="color: #0000ff;">else</span><span style="color: #000000;">{            </span><span style="color: #008080;">mysql_query</span>('ROLLBACK'<span style="color: #000000;">);            dump(</span>'commit failed, rollback!'<span style="color: #000000;">);        }        </span><span style="color: #008080;">mysql_query</span>('END'<span style="color: #000000;">);    }</span>

である場合のみサポートします。方法 2: (注: トランザクションをサポートしていない MyISAM エンジン データベースの場合、テーブル ロック方法はused)

<span style="color: #0000ff;">public</span> <span style="color: #0000ff;">function</span><span style="color: #000000;"> rollbackoriginal2(){        </span><span style="color: #800080;">$conn</span> = <span style="color: #008080;">mysql_connect</span>('127.0.0.1','summerzi','summerzi') or <span style="color: #0000ff;">die</span>('DB connection failed!'<span style="color: #000000;">);        </span><span style="color: #008080;">mysql_select_db</span>('summer',<span style="color: #800080;">$conn</span><span style="color: #000000;">);        </span><span style="color: #008080;">mysql_query</span>('set names "GBK"'<span style="color: #000000;">);        </span><span style="color: #008080;">mysql_query</span>('SET AUTOCOMMIT=0');<span style="color: #008000;">//</span><span style="color: #008000;">//设置mysql不自动提交,需自行用commit语句提交</span>        <span style="color: #800080;">$sql1</span> = "INSERT INTO `summer_userdata`(`uid`,`type`,`target_id`) VALUES(41,1,233);"<span style="color: #000000;">;        </span><span style="color: #800080;">$sql2</span> = "INSERT INTO `summer_userdata`(`uid`,`type`,`target_id`) VALUES(44,2,235);"<span style="color: #000000;">;        </span><span style="color: #008000;">//</span><span style="color: #008000;">mysql_query("LOCK TABLES `hmbl_userdata` WRITE");//锁定表</span>        <span style="color: #800080;">$res1</span> = <span style="color: #008080;">mysql_query</span>(<span style="color: #800080;">$sql1</span><span style="color: #000000;">);        </span><span style="color: #800080;">$res2</span>  = <span style="color: #008080;">mysql_query</span>(<span style="color: #800080;">$sql2</span><span style="color: #000000;">);        dump(</span><span style="color: #800080;">$sql1</span><span style="color: #000000;">);        dump(</span><span style="color: #800080;">$sql2</span><span style="color: #000000;">);        dump(</span><span style="color: #800080;">$res1</span><span style="color: #000000;">);        dump(</span><span style="color: #800080;">$res2</span><span style="color: #000000;">);        </span><span style="color: #008000;">//</span><span style="color: #008000;">mysql_query("UNLOCK TABLES");//解除锁定</span>        <span style="color: #0000ff;">if</span>(<span style="color: #800080;">$res1</span> && <span style="color: #800080;">$res2</span><span style="color: #000000;">){            </span><span style="color: #008080;">mysql_query</span>('COMMIT'<span style="color: #000000;">);            dump(</span>'commit success!'<span style="color: #000000;">);        }</span><span style="color: #0000ff;">else</span><span style="color: #000000;">{            </span><span style="color: #008080;">mysql_query</span>('ROLLBACK'<span style="color: #000000;">);            dump(</span>'commit failed, rollback!'<span style="color: #000000;">);        }        </span><span style="color: #008080;">mysql_query</span>("SET AUTOCOMMIT=1"<span style="color: #000000;">);        </span><span style="color: #008080;">mysql_query</span>('END'<span style="color: #000000;">);            }</span>

php mysql ビジネス内で複数のデータ操作が必要な場合は、トランザクション処理

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。