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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

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

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

解決済

[Laravel5] Laravel5でトランザクションが上手く動作しません。

Ayuzaki
Ayuzaki

総合スコア13

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

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

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

3回答

1グッド

0クリップ

13456閲覧

投稿2016/03/28 07:25

編集2016/03/29 01:55

現在最新のLaravel5.2で開発を行っており、トランザクションの処理で難航しております。
Eloquentを継承したModelを使用してDBとのやり取りを行っているのですが、下記のような場合はロールバックが行われません。

PHP

1// トランザクション開始 2DB::beginTransaction(); 3 4$res = m_user::where('user_id', $user_id)->update(array('status' => 1)); 5if (!$res) { 6 // ロールバック 7 DB::rollBack(); 8 return Redirect::back() 9} 10// コミット 11DB::commit();

PHP

1class m_user extends Eloquent 2{ 3 // 接続設定(独自に追加した設定) 4 protected $connection = 'my−mysql'; 5 // テーブル名 6 protected $table = 'm_user'; 7 // プライマリキー名 8 protected $primaryKey = 'user_id'; 9 // カラム名 10 protected $fillable = [ 11 'user_id' 12 ,'login_id' 13 ,'password' 14 ,'status' 15 ]; 16 // タイムスタンプ 17 public $timestamps = false; 18}

特にエラーもなくロールバックをスルーします。

しかしEloquentを使用しない、下記の場合は問題なくロールバックしてくれます。

PHP

1// トランザクション開始 2DB::beginTransaction(); 3 4$res = DB::table('m_user')->where('user_id', $user_id)->update(array('status' => 1)); 5if (!$res) { 6 // ロールバック 7 DB::rollBack(); 8 return Redirect::back() 9} 10// コミット 11DB::commit();

LaravelのトランザクションではEloquentは使用できないのでしょうか?
ご存知の方がいらっしゃいましたら教えていだだきたく存じます。
よろしくお願い致します。

KiyoshiMotoki👍を押しています

以下のような質問にはグッドを送りましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

グッドが多くついた質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

回答3

2

申し訳ございません、自己解決致しました。
私の記述ミスです。

Eloquent継承のクラスで接続先を設定しているのですが、独自に指定した接続先を指定していたのが原因でした。
(投稿時は記述ミスでデフォルト状態になっておりました。回答して下さった皆様、大変ご迷惑をおかけしました)

よって、トランザクションを開始する際に接続先を指定することにより、ロールバックが無事走りました。
※接続先my-mysqlはdatabase.phpに独自に追加した接続設定です。

PHP

1try { 2 //DBトランザクション開始 3 DB::connection('my-mysql')->transaction(function() use($login_id) { 4 $res = m_user::where('login_id', $login_id)->update(array('status' => 1)); 5 if (!$res) { 6 throw new \Exception(); 7 } 8 }); 9} 10catch(\Exception $e) 11{ 12 return Redirect::back(); 13}

Model内で接続先が変わっていればトランザクションも起きませんよね、、、お恥ずかしい限りです。
回答して下さった皆様、本当にありがとうございました。

投稿2016/03/29 01:53

Ayuzaki

総合スコア13

KiyoshiMotoki, hmiura👍を押しています

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

2

ベストアンサー

Laravelは不勉強なので推測での回答となりますが、
以下ではどうでしょうか?

php

1try { 2 DB::transaction(function () { 3 4 $res = m_user::where('user_id', $user_id)->update(array('status' => 1)); 5 if (!$res) { 6 // ロールバック 7 throw new Exception('Rollback now!!'); 8 } 9 10 }); 11} catch (Exception $e) { 12 return Redirect::back(); 13}

リファレンスによると、

If an exception is thrown within the transaction Closure, the transaction will automatically be rolled back.

「もしクロージャの中から例外が投げられたら、トランザクションは自動的にロールバックされます」
と。
そして

Note: Using the DB facade's transaction methods also controls transactions for the query builder and Eloquent ORM.

「DBファサードのtransactionメソッドを使用すると、クエリビルダーとEloquent ORMのトランザクションを制御できる」
と記載されています。
https://laravel.com/docs/5.1/database#database-transactions

また、transactionメソッドのソースコードからも、上のコードでうまく動きそうな気がします。
https://github.com/laravel/framework/blob/5.1/src/Illuminate/Database/Connection.php#L468

投稿2016/03/28 13:43

編集2016/03/28 14:08
KiyoshiMotoki

総合スコア4791

Ayuzaki, ikuwow👍を押しています

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

回答へのコメント

Ayuzaki

2016/03/29 02:04

回答ありがとうございます! 接続先設定の誤りが原因でした。申し訳ございません、私の記述ミスです。 トランザクションは基本、KiyoshiMotokiさんが回答して下さったような try-catchを利用するとのことでしたので、回答の参考にさせて頂きました。 ありがとうございます。
KiyoshiMotoki

2016/03/29 02:22

解決されたようで何よりです。 > トランザクションは基本、KiyoshiMotokiさんが回答して下さったような try-catchを利用するとのことでしたので 私が言ったわけではありませんが。。

1

トランザクションは一般的にtry-catchを利用するのですが。。。

$res = m_user::query()->where('user_id', $user_id)->update(array('status' => 1));

こちらを試して見てくれませんか?

しかしながらクラス名がそれだとPSR-4の恩恵が無いので大変そうですね。
普通はUpperCamelCaseで記述します

投稿2016/03/28 12:40

編集2016/03/28 13:13
fagai

総合スコア2154

Ayuzaki👍を押しています

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

回答へのコメント

Ayuzaki

2016/03/29 02:02

回答ありがとうございます! 自己回答にもありますが、私の接続先設定ミスが原因でした、、、申し訳ございません。 >トランザクションは一般的にtry-catchを利用するのですが。。。 教えていただきありがとうございます!基本を知らずお恥ずかしい限りです。 >しかしながらクラス名がそれだとPSR-4の恩恵が無いので大変そうですね。 ありがとうございます。勉強します。

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

ただいまの回答率
86.12%

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

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

質問する

関連した質問

同じタグがついた質問を見る

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

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

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。