Я пытаюсь разработать приложение rails на postgresql, используя последовательность для увеличения поля вместо рубинового подхода по умолчанию на основе validates_uniqueness_of.
Это оказалось сложным по ряду причин:
1. Это миграция существующей таблицы, а не новой таблицы или столбца
2. Использование параметра: default => "nextval ('seq')" не работает, поскольку он пытается установить его в скобках
3. В конечном итоге миграция работает в 2 этапа:
change_column :work_commencement_orders, :wco_number_suffix, :integer, :null => false#, :options => "set default nextval('wco_number_suffix_seq')"
execute %{
ALTER TABLE work_commencement_orders ALTER COLUMN wco_number_suffix SET DEFAULT nextval('wco_number_suffix_seq');
}
Теперь, похоже, все сделано правильно в базе данных разработки, и схема выглядит следующим образом:
wco_number_suffix | integer | not null default nextval('wco_number_suffix_seq'::regclass)
Тем не менее, тесты не пройдены с
PGError: ERROR: null value in column "wco_number_suffix" violates not-null constraint
: INSERT INTO "work_commencement_orders" ("expense_account_id", "created_at",
"process_id", "vo2_issued_on", "wco_template", "updated_at", "notes", "process_type",
"vo_number", "vo_issued_on", "vo2_number", "wco_type_id", "created_by",
"contractor_id", "old_wco_type", "master_wco_number", "deadline", "updated_by",
"detail", "elective_id", "authorization_batch_id", "delivery_lat", "delivery_long",
"operational", "state", "issued_on", "delivery_detail") VALUES(226, '2010-05-31
07:02:16.764215', 728, NULL, E'Default', '2010-05-31 07:02:16.764215', NULL,
E'Procurement::Process', NULL, NULL, NULL, 226, NULL, 276, NULL, E'MWCO-213',
'2010-06-14 07:02:16.756952', NULL, E'Name 4597', 220, NULL, NULL, NULL, 'f',
E'pending', NULL, E'728 Test Road; Test Town; 1234; Test Land') RETURNING "id"
Объяснение можно найти при проверке схемы тестовой базы данных:
wco_number_suffix | integer | not null
Так что же случилось с дефолтом?
Я пытался добавить
task:
template: smmt_ops_development
в файл database.yml, который выдает
create database smmt_ops_test template = "smmt_ops_development" encoding = 'utf8'
Я проверил, что если я его выдаю, то на самом деле он копирует nextval по умолчанию. Так ясно, что рельсы делают что-то после этого, чтобы снова это подавить.
Есть предложения, как это исправить?
Спасибо
Роберт