這篇文章給大家分享的是有關django model的update時auto_now不被更新怎么辦的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
gmt_create自動添加auto_now_add;gmt_modify自動更新auto_now
class CommonInfo(models.Model):
"""基類,提供共同信息,不會創建真實的table"""
class Meta:
# 聲明自己為抽象基類
abstract = True
# 下面表示先根據更新時間gmt_modify降序排序,如果更新時間相同,再根據創建時間gmt_create降序排序
ordering = ['-gmt_modify', '-gmt_create']
gmt_create = models.DateTimeField('創建時間,自動創建', auto_now_add=True, null=True, help_text='創建時間')
# 使用save可以達到自動更新的效果,使用update不會自動更新,因此需要攜帶上這個字段
gmt_modify = models.DateTimeField('更新時間,自動更新', auto_now=True, null=True, help_text='更新時間')django的orm關于更新數據庫的方法有update和save兩種方法。
使用save時會自動更新
obj = User.objects.get(id=1) obj.name='xxx' obj.save()
save()時確實會自動更新當前時間
這是因為這個操作它經過了model層
使用update不會自動更新;因此需要在使用filter的update更新的時候同時賦值時間為datetime.datetime.now()
如果用django filter的update(通常為批量更新數據時)則是因為直接調用sql語句 不通過 model層
User.objects.filter(id=1).update(username='xxx')
補充知識:Django的auto_now=True沒有自動更新
auto_now=True自動更新,有一個條件,就是要通過django的model層。
如create或是save方法。
如果是filter之后update方法,則直接調用的是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)的時間, # 或是如下調用save()方法 # deploy_item = DeployImage.objects.get(name=order_name) # deploy_item.deploy_status = status_item # deploy_item.save()
感謝各位的閱讀!關于“django model的update時auto_now不被更新怎么辦”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。