簡體   English   中英

在PostGres中插入NULL值后,如何自動生成ID?

[英]How do I get my IDs auto-generated when a NULL value is inserted in PostGres?

我正在使用PostGres 9.5。 我在表中進行了以下設置,希望自動生成ID…

myproject=> \d my_object_times
                               Table "public.my_object_times"
      Column       |            Type             |              Modifiers              
-------------------+-----------------------------+-------------------------------------
…
 time_in_ms        | bigint                      | 
 created_at        | timestamp without time zone | not null
 updated_at        | timestamp without time zone | not null
 name              | character varying           | 
 age               | integer                     | 
 city              | character varying           | 
 state_id          | integer                     | 
 country_id        | integer                     | 
 overall_rank      | integer                     | 
 age_group_rank    | integer                     | 
 gender_rank       | integer                     | 
 races_id          | integer                     | 
 event_id          | character varying           | 
 id                | character varying           | not null default uuid_generate_v4()

但是當我嘗試運行批量插入語句時,其內容看起來像

INSERT INTO "my_object_times" ("first_name","last_name","time_in_ms","created_at","updated_at","name","participant","age","city","state_id","country_id","overall_rank","age_group_rank","gender_rank","races_id","event_id","id","division_low_age","division_high_age") VALUES (NULL,NULL,1403000,'2016-10-12 15:36:42.766936','2016-10-12 15:36:42.767104','Terry Williamson',NULL,NULL,NULL,NULL,NULL,4,1,NULL,NULL,'0bf8c3bc-3577-4cab-bdd4-61e64655eaed',NULL,3,3),(NULL,NULL,1431000,'2016-10-12 15:36:42.766936','2016-10-12 15:36:42.767104','Casey Reinl',NULL,NULL,NULL,NULL,NULL,5,1,NULL,NULL,'0bf8c3bc-3577-4cab-bdd4-61e64655eaed',NULL,2,2),(NULL,NULL,1473000,'2016-10-12 15:36:42.766936

我得到一個錯誤

Error during processing: PG::NotNullViolation: ERROR:  null value in column "id" violates not-null constraint
DETAIL:  Failing row contains (null, null, 1403000, 2016-10-12 15:36:42.766936, 2016-10-12 15:36:42.767104, Terry Williamson, null, null, null, null, null, 4, 1, null, null, 0bf8c3bc-3577-4cab-bdd4-61e64655eaed, null, 3, 3).

我正在像這樣調用Rails 4.2.7 activerecord-import gem自動生成SQL。

MyObjectTime.import inserts

如果沒有提供我的ID,該如何為我自動生成ID?

嘗試這個,

columns_without_id = YourModel.column_names.reject { |column| column == 'id' }
import(columns_without_id, records)

參考: Github問題

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM