我错误地从表格的id字段中删除了自动增量选项。谁能告诉我如何通过迁移重新插入自动增量选项?
答案 0 :(得分:19)
尝试:
change_column :my_table, :id, :primary_key
或
my_table.change_column :id, :primary_key
某些Rails数据库适配器可能不允许您在主键上调用change_column
。如果是这种情况,那么您可以随时调用execute
直接使用SQL执行更改:
MySQL的:
execute('ALTER TABLE "my_table" CHANGE "id" "id"
bigint DEFAULT NULL auto_increment PRIMARY KEY')
PostgreSQL(方法1):
max_id = execute(%%Q{SELECT id FROM "my_table" ORDER BY "id" DESC
LIMIT 1}).to_a.first
execute(%%Q{CREATE SEQUENCE "my_table_id_seq" START #{max_id+1}})
execute(%%Q{ALTER TABLE "my_table" ALTER COLUMN "id"
TYPE bigint})
execute(%%Q{ALTER TABLE "my_table" ALTER COLUMN "id"
SET DEFAULT nextval('my_table_id_seq'::regclass)})
execute(%%Q{ALTER TABLE "my_table" ADD PRIMARY KEY("id")})
PostgreSQL(方法2):
max_id = execute(%%Q{SELECT "id" FROM "my_table" ORDER BY "id" DESC
LIMIT 1}).to_a.first
execute(%%Q{ALTER TABLE "my_table" RENAME COLUMN "id" TO "id_orig"})
execute(%%Q{ALTER TABLE "my_table" ADD COLUMN "id" bigserial NOT NULL})
execute(%%Q{UPDATE "my_table" SET "id"="id_orig"})
execute(%%Q{ALTER SEQUENCE "my_table_id_seq" RESTART #{max_id+1}})
execute(%%Q{ALTER TABLE "my_table" DROP COLUMN "id_orig"})
如果您不想使用bigint
/ bigserial
(64位),请改用int(11)
/ integer
/ serial
。
答案 1 :(得分:4)
我没有检查其他版本,但在Rails 5上你可以设置auto_increment
选项:
change_column :table_name, :id, :int, null: false, unique: true, auto_increment: true
或者如果你想要一个bigint:
change_column :table_name, :id, :bigint, null: false, unique: true, auto_increment: true
答案 2 :(得分:1)
你的Postgres代码不起作用,在ALTER TABLE语句中使用serial或bigserial是不可能的。正确的PostgreSQL SQL是
ALTER TABLE table ALTER COLUMN id TYPE int
ALTER TABLE table ALTER COLUMN id TYPE bigint
答案 3 :(得分:0)
对于那些像我一样来这里的人来说,是为了弄清楚如何制作一个使用id
而不是bigint
的自定义int
列,没有意识到对于Rails 5.1及更高版本,bigint
是id的默认类型
答案 4 :(得分:0)
更改列
Rails5
change_column :table_name, :id, :int, null: false, unique: true, auto_increment: true, primary_key: true
Rails6
change_column :table_name, :id, :int, null: false, unique: true, auto_increment: true, primary_key: true
添加列 Rails5
add_column :table_name, :id, :int, null: false, unique: true, auto_increment: true, primary_key: true
Rails6
add_column :table_name, :id, :int, null: false, unique: true, auto_increment: true, primary_key: true
答案 5 :(得分:0)
这对我有用,创建了一个主列并为所有行提供了ID。
add_column :tags_posts_rel, :id, :primary_key