DB_DataObjectのトランザクション処理。(以下サンプルコード。typoあるかも)
$tbl = DB_DataObject::factory("target_table");
$db = $tbl->getDatabaseConnection(); //これでDBオブジェクトがとれる
$db->autoCommit(False);
$db->query("BEGIN"); //トランザクション開始
$db->query("LOCK TABLE target_table IN SHARE ROW EXCLUSIVE MODE");
//必要に応じてロックレベルを設定。これはPostgreSQLのもの
//$tblにいろいろ値をセットする処理
// :
$cnt = $tbl->update();
if (PEAR::isError($tbl->_lastError) { //エラー判定
$db->query("ROLLBACK"); //ロールバック
return False;
}
if (cnt <= 0) {
$db->query("ROLLBACK");
return False;
}
$db->query("COMMIT"); //正常ならコミット
return True;
要は DBオブジェクトを取得してしまい、後はqueryメソッドで制御するという方法。
複数のテーブルを同じトランザクションでも制御できるんですが、
最初のDataObjectのオブジェクトを作ってからでないとDBオブジェクトがとれな
いのでスマートな作りとはいえません。。が、仕方なくやってます。
#自力でsetDatabaseConnection()を作る方法もあると助言もらいながらも
#時間の都合でまだ果たせず。。
PHP-Usersに投稿したのを機会にこちらにもUPです。