Rumah >rangka kerja php >ThinkPHP >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:
'params' => [ // 数据库表前缀 'prefix' => '', // 关闭字段自动类型转换 'fields_strict' => false, // 关闭自动写入时间戳 'auto_timestamp' => false, ],
$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!