猿问

求问一个 Django数据库ORM优化问题

今天突然发现Django在update一个对象时,执行的sql语句是全属性更新,而不是按需(只更新变更了的属性)更新,请问有没有什么可以优化的办法?以下代码是在django的shell环境里执行的:>>>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,有没有办法解决这个问题?
ibeautiful
浏览 443回答 2
2回答

互换的青春

Message.objects.filter(id=1).update(title="newtitle")多说一句,update能避免race-condition,正常情况下save()只需要在新建instance时用。
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答