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

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

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

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

MySQL

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Q&A

解決済

1回答

3790閲覧

[Ruby on Rails]トランザクションと悲観ロック・楽観ロックの関係性について

yomigi

総合スコア43

Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

MySQL

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

1グッド

1クリップ

投稿2020/06/29 08:30

現在RubyonRailsを用いた排他制御について学びたいと考えております。

まずRailsを用いた排他制御には以下2種類がある認識です。(ほとんど概要ですがご容赦ください)

悲観ロック
  • 「競合が起きるだろう」という前提
  • モデルのlockメソッドを使用する
楽観ロック
  • 「競合は多分起きないだろう」という前提
  • テーブルにlock_versionカラムを追加

ただ、RubyonRailsにはActiveRecord::Base.transactionというメソッドがあり
基本的には排他制御はこちらで足りるのではないかという認識です。

私の理解が間違っていましたら申し訳ないのですが、
ActiveRecord::Base.transactionを使用するだけでは足りない場合が存在するのでしょうか?
また、わざわざ上述したような実装
(モデルのlockメソッドを使用する、だったりテーブルにlock_versionカラムを追加したり、という実装です)
をしなければいけない場合ってどんな場合が該当するのでしょうか?

marigold_24👍を押しています

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

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

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

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

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

sazi

2020/06/29 08:54

トランザクション分離レベルは何ですか?
yomigi

2020/06/30 08:34

デフォルトから変えておりませんので、REPEATABLE READになります!
guest

回答1

0

ベストアンサー

複数のテーブルに対する処理が無いなら、トランザクション制御は不要で、エラー対処だけで済みます。

トランザクション制御を行うのは、整合性担保を簡単にするロールバックがあるからです。

トランザクション制御を行っても、デッドロックする要素があるなら、ロックによる排他制御が必要になります。

投稿2020/06/30 09:38

sazi

総合スコア25173

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

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

yomigi

2020/07/01 04:55

ありがとうございます! 私の理解が浅いようで申し訳ないのですが、 - トランザクションはあくまでもロールバックによる整合性担保を行うためのもの - デッドロック(例えば他のユーザが同時に同じテーブルを更新しようとした場合)の担保はトランザウションのみでは行えない =>トランザクションと排他制御は直接の関係はない?? ということであっておりますでしょうか。・・。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問