django model的update時auto_now不被更新的原因及解決方式
gmt_create自動添加auto_now_add;gmt_modify自動更新auto_now
class CommonInfo(models.Model): """基類,提供共同信息,不會創(chuàng)建真實的table""" class Meta: # 聲明自己為抽象基類 abstract = True # 下面表示先根據(jù)更新時間gmt_modify降序排序,如果更新時間相同,再根據(jù)創(chuàng)建時間gmt_create降序排序 ordering = ['-gmt_modify', '-gmt_create'] gmt_create = models.DateTimeField('創(chuàng)建時間,自動創(chuàng)建', auto_now_add=True, null=True, help_text='創(chuàng)建時間') # 使用save可以達到自動更新的效果,使用update不會自動更新,因此需要攜帶上這個字段 gmt_modify = models.DateTimeField('更新時間,自動更新', auto_now=True, null=True, help_text='更新時間')
django的orm關(guān)于更新數(shù)據(jù)庫的方法有update和save兩種方法。
使用save時會自動更新
obj = User.objects.get(id=1) obj.name='xxx' obj.save()
save()時確實會自動更新當前時間
這是因為這個操作它經(jīng)過了model層
使用update不會自動更新;因此需要在使用filter的update更新的時候同時賦值時間為datetime.datetime.now()
如果用django filter的update(通常為批量更新數(shù)據(jù)時)則是因為直接調(diào)用sql語句 不通過 model層
User.objects.filter(id=1).update(username='xxx')
補充知識:Django的auto_now=True沒有自動更新
auto_now=True自動更新,有一個條件,就是要通過django的model層。
如create或是save方法。
如果是filter之后update方法,則直接調(diào)用的是sql,不會通過model層,
所以不會自動更新此時間。官方解釋:
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.
解決辦法:
強制改成save()或是update時,帶上時間。
如下:
status_item = DeployStatus.objects.get(name=status_name) DeployImage.objects.filter(name=order_name).update( deploy_status=status_item, change_date=datetime.now()) # 上面的操作,才會更新DeployImage表里的change_date(add_now=True)的時間, # 或是如下調(diào)用save()方法 # deploy_item = DeployImage.objects.get(name=order_name) # deploy_item.deploy_status = status_item # deploy_item.save()
以上這篇django model的update時auto_now不被更新的原因及解決方式就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
國產(chǎn)化設(shè)備鯤鵬CentOS7上源碼安裝Python3.7的過程詳解
這篇文章主要介紹了國產(chǎn)化設(shè)備鯤鵬CentOS7上源碼安裝Python3.7,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-05-05Python連接MySQL數(shù)據(jù)庫并查找表信息
本文主要介紹了Python連接MySQL數(shù)據(jù)庫并查找表信息,通過使用Python中的MySQL Connector模塊,連接到MySQL服務(wù)器并執(zhí)行SQL查詢語句,可以獲取表的結(jié)構(gòu)、列信息、行數(shù)據(jù)等,感興趣的可以了解一下2023-08-08Python中使用多進程來實現(xiàn)并行處理的方法小結(jié)
本篇文章主要介紹了Python中使用多進程來實現(xiàn)并行處理的方法小結(jié),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08Python人臉識別第三方庫face_recognition接口說明文檔
Python人臉識別第三方庫face_recognition接口簡單說明,及簡單使用方法2019-05-05詳解將Pandas中的DataFrame類型轉(zhuǎn)換成Numpy中array類型的三種方法
這篇文章主要介紹了詳解將Pandas中的DataFrame類型轉(zhuǎn)換成Numpy中array類型的三種方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-07-07