Mysql
 sql >> Base de données >  >> RDS >> Mysql

Mettre à jour plusieurs colonnes à l'aide de l'objet django F()

Pour mettre à jour en utilisant models.F , vous devez construire quelque chose comme

qs.update(field_1=models.F('field_1')+field_1_delta,
          field_2=models.F('field_2')+field_2_delta, 
          ...)

Pour votre code, cela pourrait être

new_stats = {
    'NumberOfHealthPickups': 99
    # ...
}
updated_stats = {}
for stat in new_stats:
    updated_stats[stat] = models.F(stat) + new_stats[stat]
PlayerStats.objects.filter(user=user).update(**updated_stats)