


Penyelesaian kepada masalah bahawa data ThinkPHP 5 tidak boleh disimpan selepas dikemas kini
Apabila menggunakan ThinkPHP 5, apabila kami perlu mengemas kini sekeping data dalam pangkalan data, kami biasanya menggunakan fungsi $model->save() untuk menyimpannya. Walau bagaimanapun, dalam beberapa kes, kami mungkin menghadapi mesej ralat sedemikian: Data tidak boleh disimpan selepas dikemas kini. Apa yang perlu dilakukan dalam keadaan ini? Artikel ini akan memperkenalkan anda kepada beberapa penyelesaian yang mungkin.
Kaedah 1: Semak sama ada data telah dikemas kini
Apabila menggunakan fungsi $model->save() untuk operasi kemas kini, jika data tidak dikemas kini, maka $model-> Fungsi ;save() akan mengembalikan false dan menggesa mesej ralat bahawa data tidak boleh disimpan selepas dikemas kini. Oleh itu, kita boleh menyemak terlebih dahulu sama ada data telah benar-benar dikemas kini.
Pertama, kita perlu menggunakan fungsi $model->isDirty() untuk menentukan sama ada data telah dikemas kini. Contohnya:
if ($model->isDirty()) { $result = $model->save(); } else { $result = true; }
Jika data belum dikemas kini, maka fungsi $model->isDirty() akan mengembalikan false, fungsi $model->save() tidak akan dilaksanakan, dan pembolehubah $result akan diberikan nilai benar.
Kaedah 2: Matikan pengisian data automatik
Apabila menggunakan fungsi $model->save() untuk operasi kemas kini, jika medan ditakrifkan sebagai pengisian baca sahaja atau automatik, maka $ Fungsi model->save() akan mengembalikan palsu dan menggesa mesej ralat bahawa data tidak boleh disimpan selepas ia dikemas kini. Pada masa ini, kita boleh cuba mematikan fungsi autolengkap data. Langkah-langkah khusus adalah seperti berikut:
- Buka fail konfigurasi pangkalan data aplikasi config/database.php, cari tatasusunan $params dan tetapkan pilihan 'auto_timestamp' di dalamnya kepada palsu:
'params' => [ // 数据库表前缀 'prefix' => '', // 关闭字段自动类型转换 'fields_strict' => false, // 关闭自动写入时间戳 'auto_timestamp' => false, ],
- Dalam model yang perlu dikemas kini, gunakan $model->allowField(true) untuk menunjukkan tidak menggunakan fungsi autoisi:
$result = $model->allowField(true)->save($data);
Selepas melakukan ini, anda boleh mematikan fungsi auto isi data untuk mengelakkan masalah bahawa sesetengah medan ditakrifkan sebagai baca sahaja atau autoisi dan tidak boleh dikemas kini.
Kaedah 3: Tentukan secara manual medan yang perlu dikemas kini
Apabila menggunakan fungsi $model->save() untuk operasi kemas kini, kami boleh menentukan secara manual medan yang perlu dikemas kini, seperti berikut:
$result = $model->save([ 'name' => $name, 'age' => $age, ], ['id' => $id]);
Selepas menyatakan dengan cara ini, hanya medan yang ditentukan akan disimpan semasa mengemas kini data, mengelakkan masalah bahawa sesetengah medan ditakrifkan sebagai baca sahaja atau diisi secara automatik dan tidak boleh dikemas kini .
Ringkasan
Apabila kami menggunakan ThinkPHP 5 untuk mengemas kini data, kami mungkin menghadapi masalah bahawa data tidak boleh disimpan selepas dikemas kini. Untuk menangani masalah ini, kita boleh menggunakan fungsi $model->isDirty() untuk menyemak sama ada data telah dikemas kini atau mematikan fungsi auto-isi data. Jika masalah masih tidak dapat diselesaikan, maka kami boleh menentukan secara manual medan yang perlu dikemas kini untuk menyelesaikan masalah.
Atas ialah kandungan terperinci Penyelesaian kepada masalah bahawa data ThinkPHP 5 tidak boleh disimpan selepas dikemas kini. 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

AI Hentai Generator
Menjana ai hentai secara percuma.

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



Artikel ini membincangkan pertimbangan utama untuk menggunakan ThinkPhp dalam arkitek tanpa pelayan, memberi tumpuan kepada pengoptimuman prestasi, reka bentuk tanpa statik, dan keselamatan. Ia menyoroti faedah seperti kecekapan kos dan skalabiliti, tetapi juga menangani cabaran

ThinkPhp's Container IOC menawarkan ciri -ciri canggih seperti pemuatan malas, mengikat kontekstual, dan suntikan kaedah untuk pengurusan ketergantungan yang cekap di php apps.Character Count: 159

Artikel ini membincangkan rangka kerja ujian ThinkPHP, yang menonjolkan ciri-ciri utamanya seperti ujian unit dan integrasi, dan bagaimana ia meningkatkan kebolehpercayaan aplikasi melalui pengesanan bug awal dan kualiti kod yang lebih baik.

Artikel ini membincangkan pelaksanaan penemuan perkhidmatan dan mengimbangi beban dalam microservices ThinkPHP, memberi tumpuan kepada persediaan, amalan terbaik, kaedah integrasi, dan alat yang disyorkan. [159 aksara]

Artikel ini menggariskan membina sistem giliran tugas yang diedarkan menggunakan ThinkPhp dan RabbitMQ, yang memberi tumpuan kepada pemasangan, konfigurasi, pengurusan tugas, dan skalabilitas. Isu -isu utama termasuk memastikan ketersediaan yang tinggi, mengelakkan perangkap biasa seperti implope

Artikel ini membincangkan amalan terbaik untuk mengendalikan muat naik fail dan mengintegrasikan penyimpanan awan di ThinkPhp, yang memberi tumpuan kepada keselamatan, kecekapan, dan skalabiliti.

Artikel membincangkan menggunakan ThinkPHP untuk suapan data pasaran saham masa nyata, memberi tumpuan kepada persediaan, ketepatan data, pengoptimuman, dan langkah-langkah keselamatan.

Artikel ini membincangkan menggunakan ThinkPHP untuk membina alat kerjasama masa nyata, memberi tumpuan kepada persediaan, integrasi WebSocket, dan amalan terbaik keselamatan.
