Rails 4 能原生態的支援Postgres 中的UUID(Universally Unique Identifier,可通用的唯一識別碼)類型。在此,我將向你描述如何在不用手工修改任何Rails代碼的情況下,用它來產生UUID。
首先,你需要啟用Postgres的擴充外掛程式‘uuid-ossp':
class CreateUuidPsqlExtension < ActiveRecord::Migration def self.up execute "CREATE EXTENSION \"uuid-ossp\";" end def self.down execute "DROP EXTENSION \"uuid-ossp\";" endend
你可以用UUID作為一個ID來進行替換:
create_table :translations, id: :uuid do |t| t.string :title t.timestampsend
在此例中,翻譯表會把一個UUID作為ID來自動產生它。Postgresq的uuid-ossp擴充外掛程式所用演算法和產生UUID的演算法是不同的。Rails 4預設使用的是v4演算法. 你可以在這裡: http://www.postgresql.org/docs/current/static/uuid-ossp.html 看到更多有關這些演算法的細節。
然而,有時候你不想用UUID作為ID來進行替換。那麼,你可以另起一列來放置它:
class AddUuidToModelsThatNeedIt < ActiveRecord::Migration def up add_column :translations, :uuid, :uuid end def down remove_column :invoices, :uuid endend
這會建立一個放置UUID的列,但這個UUID不會自動產生。你不得不在Rails中用SecureRandom來產生它。但是,我們認為這是一個典型的資料庫職責行為。值得慶幸的是,add_column中的預設選項會幫我們實現這種行為:
class AddUuidToModelsThatNeedIt < ActiveRecord::Migration def up add_column :translations, :uuid, :uuid, :default => "uuid_generate_v4()" end def down remove_column :invoices, :uuid endend
現在,UUID能被自動建立了。同理也適用於已有記錄!