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"
嗯對不起,其實後者的解決方案工作。 –