Maison  >  Article  >  cadre php  >  Solution au problème selon lequel les données ThinkPHP 5 ne peuvent pas être enregistrées après la mise à jour

Solution au problème selon lequel les données ThinkPHP 5 ne peuvent pas être enregistrées après la mise à jour

PHPz
PHPzoriginal
2023-04-11 15:10:05920parcourir

Lorsque nous utilisons ThinkPHP 5, lorsque nous devons mettre à jour une donnée dans la base de données, nous utilisons généralement la fonction $model->save() pour la sauvegarder. Cependant, dans certains cas, nous pouvons rencontrer le message d'erreur suivant : Les données ne peuvent pas être enregistrées après la mise à jour. Que faire dans cette situation ? Cet article vous présentera plusieurs solutions possibles.

Méthode 1 : Vérifiez si les données ont été mises à jour

Lorsque vous utilisez la fonction $model->save() pour effectuer une opération de mise à jour, si les données ne sont pas mises à jour, la fonction $model->save() le fera return false et un message d'erreur indiquant que les données ne peuvent pas être enregistrées après la mise à jour s'affiche. Nous pouvons donc d’abord vérifier si les données ont effectivement été mises à jour.

Tout d'abord, nous devons utiliser la fonction $model->isDirty() pour déterminer si les données ont été mises à jour. Par exemple :

if ($model->isDirty()) {
    $result = $model->save();
} else {
    $result = true;
}

Si les données ne sont pas mises à jour, alors la fonction $model->isDirty() retournera false, la fonction $model->save() ne sera pas exécutée et la variable $result sera attribué la valeur true.

Méthode 2 : Désactiver le remplissage automatique des données

Lors de l'utilisation de la fonction $model->save() pour les opérations de mise à jour, si un champ est défini en lecture seule ou en remplissage automatique, alors la fonction $model-> Fonction save() Elle renverra false et affichera un message d'erreur indiquant que les données ne peuvent pas être enregistrées après la mise à jour. À ce stade, nous pouvons essayer de désactiver la fonction de saisie automatique des données. Les étapes spécifiques sont les suivantes :

  1. Ouvrez le fichier de configuration de la base de données de l'application config/database.php, recherchez le tableau $params et définissez l'option 'auto_timestamp' sur false :
'params' => [
    // 数据库表前缀
    'prefix' => '',
    // 关闭字段自动类型转换
    'fields_strict' => false,
    // 关闭自动写入时间戳
    'auto_timestamp' => false,
],
  1. Dans le modèle qui a besoin pour être mis à jour, utilisez $model->allowField(true) signifie ne pas utiliser la fonction de remplissage automatique :
$result = $model->allowField(true)->save($data);

Après avoir fait cela, vous pouvez désactiver la fonction de remplissage automatique des données, évitant ainsi le problème que certains champs sont défini en lecture seule ou en remplissage automatique et ne peut pas être mis à jour.

Méthode 3 : Spécifiez manuellement les champs qui doivent être mis à jour

Lorsque vous utilisez la fonction $model->save() pour effectuer l'opération de mise à jour, nous pouvons spécifier manuellement les champs qui doivent être mis à jour, comme indiqué ci-dessous :

$result = $model->save([
    'name' => $name,
    'age'  => $age,
], ['id' => $id]);

Après avoir spécifié de cette manière, lors de la mise à jour des données, seuls les champs spécifiés seront enregistrés, évitant ainsi le problème selon lequel certains champs sont définis comme en lecture seule ou remplis automatiquement et ne peuvent pas être mis à jour.

Résumé

Lorsque nous utilisons ThinkPHP 5 pour mettre à jour des données, nous pouvons rencontrer le problème que les données ne peuvent pas être enregistrées après la mise à jour. Pour résoudre ce problème, nous pouvons utiliser la fonction $model->isDirty() pour vérifier si les données ont été mises à jour, ou désactiver la fonction de remplissage automatique des données. Si le problème ne peut toujours pas être résolu, nous pouvons alors spécifier manuellement les champs qui doivent être mis à jour pour résoudre le problème.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn