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

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

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

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

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

Q&A

1回答

4770閲覧

Railsでグループごとに連番を振る方法

opoonabst

総合スコア264

Ruby

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

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

0グッド

1クリップ

投稿2016/11/20 04:06

Railsで2ちゃんねるみたいにスレッドごとに1から始まる一意の連番を振りたいと思っています。
↓のような形

スレッドIDコメント番号コメント
11hoge
12fuga
21foo
13bar
22fizzz
31piyo

before_createでコメント番号のMAX値を取ってきてプラス1加算したものを
コメント番号として設定する、という方法を使おうと思ったのですが、

これだと書き込み頻度が高くなり同時書き込みが発生してしまうと値が重複して変なことになってしまいます。
DB側でユニーク制約を設定する、というのは行ってみたのですが、
これだと整合性は保てても同時に書き込まれた際に致命的なエラーが発生してしまいます。

整合性を保ったまま、かつエラーを発生させない、となるとどのような実装方法になるのでしょうか?

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

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

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

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

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

guest

回答1

0

Rails上で可能であるかは分かりませんが、Postgres的には下記の方法が有ると思います。

・スレッドID発番テーブルを作成(初期設定) create table num_tbl(id int, num int); ・初期値セット(スレッド作成時) insert into num_tbl values(1,0); ・作成時 MAX値取得 (スレッドid:1の場合) update num_tbl set num=num+1 where id=1 returning num; ・インサートのコメント番号値に利用する。

同時更新の際でもユニークな番号が発番されます。(ROW LOCKが発生する事を想定)

投稿2016/11/20 11:11

A.Ichi

総合スコア4070

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問