第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

求問一個 Django數據庫ORM優(yōu)化問題

求問一個 Django數據庫ORM優(yōu)化問題

ibeautiful 2019-03-29 10:59:50
今天突然發(fā)現Django在update一個對象時,執(zhí)行的sql語句是全屬性更新,而不是按需(只更新變更了的屬性)更新,請問有沒有什么可以優(yōu)化的辦法?以下代碼是在django的shell環(huán)境里執(zhí)行的:>>>fromdjango.dbimportconnection>>>printconnection.queries[]>>>frommyproj.msgimportMessage>>>m=Message.objects.get(id=1)>>>m.title='newmsgtitle'>>>m.save()>>>printconnection.queries[{'time':'0.002','sql':u'SELECT`myproj_msg`.`id`,`myproj_msg`.`creator_id`,`myproj_msg`.`title`,`myproj_msg`.`content`FROM`myproj_msg`WHERE`myproj_msg`.`id`=1'},{'time':'0.001','sql':u'SELECT(1)AS`a`FROM`myproj_msg`WHERE`myproj_msg`.`id`=1LIMIT1'},{'time':'0.054','sql':u'UPDATE`myproj_msg`SET`creator_id`=1,`title`='newmsgtitle',`content`='oldcontent'WHERE`myproj_msg`.`id`=1'}]如上代碼所示,其實只是像更新“消息”對象的標題,當django對整個對象的所有屬性做了update操作,如果content內容非常大,可能會導致數據庫瓶頸,如果不想繞過django的ORM自己寫sql,有沒有辦法解決這個問題?
查看完整描述

2 回答

?
互換的青春

TA貢獻1797條經驗 獲得超6個贊

Message.objects.filter(id=1).update(title="newtitle")多說一句,update能避免race-condition,正常情況下save()只需要在新建instance時用。
                            
查看完整回答
反對 回復 2019-03-29
  • 2 回答
  • 0 關注
  • 454 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號