小编Mar*_*ark的帖子

使用UUID主键进行ActiveRecord迁移

在我想要创建的迁移中,表的主键是一个名为"id"的字段,但它不是一个自动递增的整数.它的数据类型应该是uniqueidentifier(一个uuid).这是我尝试过的:

create_table :some_things, :id => false do |t|
  t.column :id, :uniqueidentifier, :primary => true
  t.column :name, :string, :limit => 255
  t.column :type, :tinyint
  t.column :deleted_flag, :bit
  t.column :class_id, :uniqueidentifier
  t.timestamps
end
Run Code Online (Sandbox Code Playgroud)

这会创建表,但没有主键(因为我说:id => false).如果我说"create_table:some_things,:id => true,:primary =>:id",则"id"成为主键,但它是一个自动递增的整数,而不是非自动递增的uuid.

如何使此迁移工作,以便主键是一个名为"uniqueidentifier"类型的"id"字段(非自动递增)?

我正在使用:SQL Server 2008,Rails/ActiveRecord 3.0.3,activerecord-sqlserver-adapter gem和ODBC连接.

sql-server primary-key rails-migrations ruby-on-rails-3

6
推荐指数
1
解决办法
1675
查看次数