django model的update時(shí)auto_now不被更新的原因及解決方式
gmt_create自動(dòng)添加auto_now_add;gmt_modify自動(dòng)更新auto_now
class CommonInfo(models.Model):'''基類(lèi),提供共同信息,不會(huì)創(chuàng)建真實(shí)的table'''class Meta: # 聲明自己為抽象基類(lèi) abstract = True # 下面表示先根據(jù)更新時(shí)間gmt_modify降序排序,如果更新時(shí)間相同,再根據(jù)創(chuàng)建時(shí)間gmt_create降序排序 ordering = [’-gmt_modify’, ’-gmt_create’]gmt_create = models.DateTimeField(’創(chuàng)建時(shí)間,自動(dòng)創(chuàng)建’, auto_now_add=True, null=True, help_text=’創(chuàng)建時(shí)間’)# 使用save可以達(dá)到自動(dòng)更新的效果,使用update不會(huì)自動(dòng)更新,因此需要攜帶上這個(gè)字段gmt_modify = models.DateTimeField(’更新時(shí)間,自動(dòng)更新’, auto_now=True, null=True, help_text=’更新時(shí)間’)
django的orm關(guān)于更新數(shù)據(jù)庫(kù)的方法有update和save兩種方法。
使用save時(shí)會(huì)自動(dòng)更新
obj = User.objects.get(id=1)obj.name=’xxx’obj.save()
save()時(shí)確實(shí)會(huì)自動(dòng)更新當(dāng)前時(shí)間
這是因?yàn)檫@個(gè)操作它經(jīng)過(guò)了model層
使用update不會(huì)自動(dòng)更新;因此需要在使用filter的update更新的時(shí)候同時(shí)賦值時(shí)間為datetime.datetime.now()
如果用django filter的update(通常為批量更新數(shù)據(jù)時(shí))則是因?yàn)橹苯诱{(diào)用sql語(yǔ)句 不通過(guò) model層
User.objects.filter(id=1).update(username=’xxx’)
補(bǔ)充知識(shí):Django的auto_now=True沒(méi)有自動(dòng)更新
auto_now=True自動(dòng)更新,有一個(gè)條件,就是要通過(guò)django的model層。
如create或是save方法。
如果是filter之后update方法,則直接調(diào)用的是sql,不會(huì)通過(guò)model層,
所以不會(huì)自動(dòng)更新此時(shí)間。官方解釋?zhuān)?/b>
What you consider a bug, others may consider a feature, e.g. usingupdate_fieldsto bypass updating fields withauto_now. In fact, I wouldn’t expectauto_nowfields to be updated if not present inupdate_fields.
解決辦法:
強(qiáng)制改成save()或是update時(shí),帶上時(shí)間。
如下:
status_item = DeployStatus.objects.get(name=status_name) DeployImage.objects.filter(name=order_name).update( deploy_status=status_item, change_date=datetime.now()) # 上面的操作,才會(huì)更新DeployImage表里的change_date(add_now=True)的時(shí)間, # 或是如下調(diào)用save()方法 # deploy_item = DeployImage.objects.get(name=order_name) # deploy_item.deploy_status = status_item # deploy_item.save()
以上這篇django model的update時(shí)auto_now不被更新的原因及解決方式就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. Python多線程操作之互斥鎖、遞歸鎖、信號(hào)量、事件實(shí)例詳解2. Python常用GUI框架原理解析匯總3. XML入門(mén)的常見(jiàn)問(wèn)題(一)4. Django程序的優(yōu)化技巧5. Jsp中request的3個(gè)基礎(chǔ)實(shí)踐6. idea設(shè)置自動(dòng)導(dǎo)入依賴(lài)的方法步驟7. jsp EL表達(dá)式詳解8. 怎樣才能用js生成xmldom對(duì)象,并且在firefox中也實(shí)現(xiàn)xml數(shù)據(jù)島?9. IntelliJ IDEA 統(tǒng)一設(shè)置編碼為utf-8編碼的實(shí)現(xiàn)10. django 鏈接多個(gè)數(shù)據(jù)庫(kù) 并使用原生sql實(shí)現(xiàn)
