2015-10-31 155 views
2

我有一個模型與ArrayField(),並希望爲它附加一個值。Django ArrayField追加,避免競爭條件

我可以這樣做:

self.my_array_field.append("foobar") 

然而,這往往失敗,因爲競爭條件。

所以,我想是這樣的:

self.my_array_field = F('my_array_field') + "foobar" 

這樣的:

self.my_array_field = F('my_array_field').append("foobar") 

這:

self.my_array_field = Func(F('my_array_field'), Value("foobar"), function='array_append') 

不幸的是所有這些完全的失敗。

你會建議我在django中實現這個PostGreSQL語句嗎?

UPDATE my_model SET my_array_field = array_append(my_array_field, "foobar") 

注意,這種說法也相當於:

UPDATE my_model SET my_array_field = my_array_field || "foobar" 
+0

嗯對不起,其實後者的解決方案工作。 –

回答

1

其實,這個解決方案正常工作:

self.my_array_field = Func(F('my_array_field'), Value("foobar"), function='array_append')