Есть ли способ увеличить год для отфильтрованных объектов с помощью метода update ()?
Я использую:
python 2.6.5
django 1.2.1 final
mysql Ver 14.14 Distrib 5.1.41
Я знаю, что можно сделать что-то вроде этого:
today = datetime.datetime.today()
for event in Event.objects.filter(end_date__lt=today).iterator():
event.start_date = festival.start_date + datetime.timedelta(365)
event.end_date = festival.end_date + datetime.timedelta(365)
event.save()
Однако в некоторых случаях я бы предпочел использовать метод update ().
# This does not work..
Event.objects.all().update(
start_date=F('start_date') + datetime.timedelta(365),
end_date=F('end_date') + datetime.timedelta(365)
)
В приведенном выше примере я получаю:
Warning: Truncated incorrect DOUBLE value: '365 0:0:0'
SQL-запрос, который он пытается сделать:
UPDATE `events_event` SET `start_date` = `events_event`.`start_date` + 365 days, 0:00:00, `end_date` = `events_event`.`end_date` + 365 days, 0:00:00
Я нашел кое-что в руководстве по mysql, но это неформатированный sql!
SELECT DATE_ADD('2008-12-15', INTERVAL 1 YEAR);
Есть идеи?