我有一个事件模型,其中包括一个“开始时间”字段,该字段存储在UTC中并映射到DB中。该模型还具有一个start_local()助手函数,它将事件启动作为用户本地时间中的Datetime对象返回。这是通过事件实例对用户的引用实现的,然后是具有时区信息的get_profile()。
这是可行的,但问题是,当我显示长的事件列表时,由于用户和概要文件的查找,每行有2个DB查询。这是愚蠢的,因为时区在行之间不是可变的,但是模型不知道这一点。我的当前设置将时区信息传递给start_local(),这解决了速度问题,但从设计的角度来看并不是一个很好的选择。事件实例知道如何获取用户的时区,并且必须依赖调用函数来帮助避免大性能his的麻烦。
有人对将时区信息传递给助手函数有改进吗?
发布于 2012-02-07 19:13:29
使用select_related。我忘记了什么时候引入了OneToOne select关联,但它适用于1.3。
User.objects.select_related('userprofile')
# assuming the profile is called userprofile
Event.objects.select_related('user', 'user__profile')https://stackoverflow.com/questions/9182287
复制相似问题