Rails 3.0.20およびRuby 1.8.7(2011-06-30パッチレベル352)を使用します
GUIDを生成するのに最適なプラグインを提案してください。
たくさんのオプションがありますが、追加の依存関係を追加せず、組み込みのSecureRandom
を使用することをお勧めします。
SecureRandom.uuid #=> "1ca71cd6-08c4-4855-9381-2f41aeffe59c"
他の可能な形式を参照してください here 。
最初に提案するのは、RubyおよびRailsバージョンをアップグレードしてください。
Guidを生成する非常に良い方法は SecureRandom です。これはRubyモジュールです。簡単に使用できます。
require 'securerandom'
guid = SecureRandom.hex(10) #or whatever value you want instead of 10
PostgreSQLを使用し、組み込みのuuid列を使用することをお勧めします。列を作成するタイプに基づいてUUIDを自動生成します。
Rails 3移行の例
execute <<-SQL CREATE TABLE some_items (id uuid PRIMARY KEY DEFAULT uuid_generate_v1()); SQL
Rails 4でこれを行うより良い方法かもしれません。
Securerandom Ruby標準ライブラリを使用してRails 3.Xおよび4.Xの例を使用してUUIDを使用する方法の詳細を参照してください。
lib/usesguid.rbにusesguid.rbファイルを作成し、その中に以下のコードを貼り付けます-
require 'securerandom'
module ActiveRecord
module Usesguid #:nodoc:
def self.append_features(base)
super
base.extend(ClassMethods)
end
module ClassMethods
def usesguid(options = {})
class_eval do
self.primary_key = options[:column] if options[:column]
after_initialize :create_id
def create_id
self.id ||= SecureRandom.uuid
end
end
end
end
end
end
ActiveRecord::Base.class_eval do
include ActiveRecord::Usesguid
end
config/application.rbに次の行を追加してファイルをロードします-
require File.dirname(__FILE__) + '/../lib/usesguid'
以下に示すように、UUID関数の移行スクリプトを作成します-
class CreateUuidFunction < ActiveRecord::Migration
def self.up
execute "create or replace function uuid() returns uuid as 'uuid-ossp', 'uuid_generate_v1' volatile strict language C;"
end
def self.down
execute "drop function uuid();"
end
end
連絡先の移行の例と使用方法を次に示します-
class CreateContacts < ActiveRecord::Migration
def change
create_table :contacts, id: false do |t|
t.column :id, :uuid, null:false
t.string :name
t.string :mobile_no
t.timestamps
end
end
end
モデルへの最終的な使用方法
class Contact < ActiveRecord::Base
usesguid
end
これは、RailsアプリケーションのUUIDを構成するのに役立ちます。
これは、Rails 3.0、3.1、3.2、および4.0でも役立ちます。
使用中に問題が発生した場合は、とても簡単にお知らせください!
Rails4のその他のオプション here