有沒有辦法使用update()方法增加過濾對象的年份?如何使用update()在Django的datetimefield中增加年份?
我使用:
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);
任何想法?
似乎是一個開放的車票與補丁:http://code.djangoproject.com/ticket/10154 – OmerGertel 2010-11-04 06:08:46