質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

1回答

3963閲覧

Wordpress SQL処理でのロールバック、コミットについて

omusoba

総合スコア29

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2016/10/27 09:22

こんにちは。

現在Wordpressを使ってサイトを作成しています。
その際にWordpressで複数のテーブルのデータベースの更新を行い、いずれかが失敗したらロールバックしたいと考えています。

PHP

1$result1 = update_user_meta( $user->ID, 'nickname', $st_nickname ); 2$result2 = update_user_meta( $user->ID, 'accesstoken', $user_token ); 3 4if( $result1 === true && $result2 === true){ 5 6mysql_query("commit"); //確定 7print "コミットしました"; 8 9}else{ 10 11mysql_query("rollback"); //巻き戻し 12print "ロールバックしました"; 13 14}

Wordpress関数を使ってユーザーのメタ情報をアップデートした後にロールバックができるか試してみました。
正常処理は問題ありませんでした。
デバッグ時に意図的に片方の判定をfalseになるように変えて行いましたがロールバックはされず、true判定がされている方のみが更新されます。

もしかしたら何かしらの形でコールバック処理を許可しないと行けないのかなと考えておりますが、ご存知の方がいらっしゃいましたらお伺いできればと思います。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

トランザクションを開始していないからだと思われます。

ご提示のコードの先頭に、以下の1行を追加してください。

php

1mysql_query('START TRANSACTION');

投稿2016/10/27 09:37

KiyoshiMotoki

総合スコア4791

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

omusoba

2016/10/27 09:39

やっぱりたりなかったのですね! ちなみに終わりの部分には何か追加しなくても問題はないですか?
KiyoshiMotoki

2016/10/27 09:45

> ちなみに終わりの部分には何か追加しなくても問題はないですか? 問題ありません。 https://dev.mysql.com/doc/refman/5.6/ja/commit.html > ・START TRANSACTION または BEGIN は、新しいトランザクションを開始します。 > ・COMMIT は、現在のトランザクションをコミットして、その変更を永続的なものにします。 > ・ROLLBACK は、現在のトランザクションをロールバックして、その変更を取り消します。
omusoba

2016/10/28 03:15

ありがおうございます。 これで考えていた通りの処理ができました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問