使用Ruby on Rails和PostgreSQL自動產生UUID的教程_ruby專題

來源:互聯網
上載者:User

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能被自動建立了。同理也適用於已有記錄!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.