


Bagaimana untuk mengemas kini nilai berbilang kunci dalam JsonField menggunakan kaedah .update() menggunakan ORM Django?
Saya mempunyai medan model yang saya cuba gunakan dengan Django's .update()
方法进行更新。该字段是一个 jsonfield。我通常会在这个领域保存一本字典。例如{"test": "是", "prod": "否"}
Ini modelnya:
class question(models.model): # {"test": "yes", "prod": "no"} extra_data = models.jsonfield(default=dict, null=true, blank=true)
Saya boleh mengemas kini kunci dalam kamus menggunakan pertanyaan ini (yang berfungsi dengan baik):
Question.filter(id="123").update(meta_data=Func( F("extra_data"), Value(["test"]), Value("no", JSONField()), function="jsonb_set", ))
Sekarang persoalannya, adakah cara yang boleh saya gunakan .update()
untuk mengemas kini berbilang kunci (dalam kes saya sendiri dua) serentak seperti yang ditunjukkan dalam pertanyaan di atas?
Saya mahu menggunakan kaedah .update()
方法而不是 .save()
dan bukannya .save()
untuk mencapai ini supaya saya boleh mengelak daripada memanggil fungsi isyarat post_save.
Jawapan Betul
Penafian: Ia akan kelihatan hodoh.
Saya pernah melakukan ini pada masa lalu, walaupun menggunakan sql tulen, bukan django. Ideanya adalah untuk memanggil secara rekursif jsonb_set()
. Setiap panggilan menetapkan kunci.
Jadi, dalam sql, untuk menetapkan kunci {"test":"yes","prod":"no"}
anda lakukan:
update question set meta_data = jsonb_set(jsonb_set(extra_data, '{test}', '"yes"'::jsonb), '{prod}', '"no"'::jsonb) where id = 123;
Sila ambil perhatian bahawa terdapat dua panggilan bersarang ke jsonb_set, yang paling dalam digunakan meta_data
, dan yang paling luar menerima hasil yang paling dalam.
Jadi persamaan django kelihatan seperti ini (nota, belum diuji):
question.filter(id="123").update( meta_data=func( func( f("extra_data"), value(["test"]), value("yes", jsonfield()), function="jsonb_set", ), value(["prod"]), value("no", jsonfield()), function="jsonb_set", ))
Atau anda boleh mencipta fungsi rekursif yang mengembalikan kekacauan untuk anda, menetapkan satu item pada satu masa:
def recursive_jsonb_set(original, **kwargs): if kwargs: key, value = kwargs.popitem() return Func( recursive_jsonb_set(original, **kwargs), Value(key.split('__')), Value(value, JSONField()), function="jsonb_set") else: return original Question.filter(id="123").update( meta_data=recursive_jsonb_set(F("extra_data"), test="yes", prod="no", other__status="done"))
Sila ambil perhatian fungsi '__'
untuk mengemas kini kanak-kanak.
Atas ialah kandungan terperinci Bagaimana untuk mengemas kini nilai berbilang kunci dalam JsonField menggunakan kaedah .update() menggunakan ORM Django?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Penyelesaian kepada Isu Kebenaran Semasa Melihat Versi Python di Terminal Linux Apabila anda cuba melihat versi Python di Terminal Linux, masukkan Python ...

Bagaimana Mengajar Asas Pengaturcaraan Pemula Komputer Dalam masa 10 jam? Sekiranya anda hanya mempunyai 10 jam untuk mengajar pemula komputer beberapa pengetahuan pengaturcaraan, apa yang akan anda pilih untuk mengajar ...

Apabila menggunakan Perpustakaan Pandas Python, bagaimana untuk menyalin seluruh lajur antara dua data data dengan struktur yang berbeza adalah masalah biasa. Katakan kita mempunyai dua DAT ...

Cara mengelakkan dikesan semasa menggunakan fiddlerevery di mana untuk bacaan lelaki-dalam-pertengahan apabila anda menggunakan fiddlerevery di mana ...

Bagaimanakah Uvicorn terus mendengar permintaan HTTP? Uvicorn adalah pelayan web ringan berdasarkan ASGI. Salah satu fungsi terasnya ialah mendengar permintaan HTTP dan teruskan ...

Di Python, bagaimana untuk membuat objek secara dinamik melalui rentetan dan panggil kaedahnya? Ini adalah keperluan pengaturcaraan yang biasa, terutamanya jika perlu dikonfigurasikan atau dijalankan ...

Menggunakan Python di Terminal Linux ...

Memahami Strategi Anti-Crawling of Investing.com Ramai orang sering cuba merangkak data berita dari Investing.com (https://cn.investing.com/news/latest-news) ...
