Mysql
 sql >> Database >  >> RDS >> Mysql

Aggiorna più colonne usando l'oggetto django F()

Per aggiornare utilizzando models.F , devi costruire qualcosa come

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

Per il tuo codice, potrebbe essere

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)