ホームページ > バックエンド開発 > PHPチュートリアル > PHP PDO トランザクション commit mysql ステートメント

PHP PDO トランザクション commit mysql ステートメント

WBOY
リリース: 2016-06-23 14:39:02
オリジナル
933 人が閲覧しました

$db = new PDO ( 'mysql:host=' . $cfg ['hostanme'] . ';dbname=' . $cfg ['dbname'], $cfg ['username'], $cfg ['password'] );		$db->exec ( "set character_set_client = utf8" );		$db->exec ( "SET character_set_results =utf8" );		$db->exec ( "SET character_set_connection = utf8" );				$db->query ( "BEGIN" ); // 事务开始				$calories ="sa阿萨德";		$sth = $db->prepare(' INSERT INTO `test_user`  values ( null,1, :calories);');		$sth->execute(array(':calories' => $calories ));				$sths = $db->prepare(' INSERT INTO `test_users`  values ( null,1, :calories);');		$sths->execute(array(':calories' => $calories )); //故意写错的				$lastid = $db->lastInsertId();						$sd = $sth->rowCount();
ログイン後にコピー


聞きたいのですが、このようにトランザクションを処理する場合、一度に 1 つの SQL だけを実行して判断することはできますか? SQL文が多い場合、例えば10個以上ある場合、10個以上書いて10回以上判定する必要があるのではないでしょうか?一度に複数の SQL トランザクションを実行することはできますか?さらに、MySQL のストアド プロシージャにトランザクションを記述するにはどうすればよいでしょうか? PHPを呼び出すにはどうすればよいですか?


ディスカッションへの返信 (解決策)

DROP PROCEDURE IF EXISTS pro_rep_shadow_rs;create procedure pro_rep_shadow_rs(out rtn int)   begin       -- 如果出现异常,会自动处理并rollback    declare exit handler for  sqlexception ROLLBACK ;     		           -- 启动事务       start transaction;       insert into test_user values(NULL,1,'啊是大三的');		insert into test_user VALUES(NULL,23,'sdsd',ss); --故意写错的           -- 运行没有异常,提交事务       commit;       -- 设置返回值为1      set rtn=1;   end;   
ログイン後にコピー

結局のところ、トランザクションを実行するにはストアド プロシージャを使用する方がはるかに便利です

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート