有时候,使用数据库中自带的“auto increment”可能不能满足需求,这个时候如果是真的需要一个唯一的可以跨数据库应用的主键时,我们得使用UUID(Universally Unique IDentifier)来做这事。
由UUID生成的主键是唯一的,如12f186e6-687e-11ad-843e-001b632783f1这个随机字符串。
创建表(Model)
Model中的设置
安装UUID生成器gem:
在lib目录中创建UUIDHelper模块
然后在Model中将UUID生成模块插进来:
现在,当你新增一个Post记录,保存后,uuid字段会自动填充uuid序列。你还期待什么呢?
由UUID生成的主键是唯一的,如12f186e6-687e-11ad-843e-001b632783f1这个随机字符串。
创建表(Model)
create_table :posts, :id => false do |t|
t.string :uuid, :limit => 36, :primary => true
end
Model中的设置
class Post < ActiveRecord::Base
set_primary_key "uuid"
end
安装UUID生成器gem:
sudo gem install uuidtools
在lib目录中创建UUIDHelper模块
require 'rubygems'
require 'uuidtools'
module UUIDHelper
def before_create()
self.uuid = UUID.timestamp_create().to_s
end
end
然后在Model中将UUID生成模块插进来:
class Post < ActiveRecord::Base
set_primary_key "uuid"
include UUIDHelper
end
现在,当你新增一个Post记录,保存后,uuid字段会自动填充uuid序列。你还期待什么呢?