Rumah >rangka kerja php >ThinkPHP >Penyelesaian kepada masalah bahawa data ThinkPHP 5 tidak boleh disimpan selepas dikemas kini

Penyelesaian kepada masalah bahawa data ThinkPHP 5 tidak boleh disimpan selepas dikemas kini

PHPz
PHPzasal
2023-04-11 15:10:05992semak imbas

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:

  1. 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,
],
  1. 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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn