2010-04-05 241 views
1

对象用户有一个外键关系来解决。样本1和2之间是否有区别?样本1是否多次运行查询?或者是地址对象缓存?Django的数据库缓存

# Sample 1 
country = user.address.country 
city = user.address.city 
state = user.address.state 

# Sample 2 
address = user.address 
country = address.country 
city = address.city 
state = address.state 

回答

1

地址对象确实被高速缓存。你可以看到这一点,如果你之前和访问user.address后打印的user.__dict__内容。例如:

>>> user.__dict__ 
{'date_joined': datetime.datetime(2010, 4, 1, 12, 31, 59), 
'email': u'[email protected]', 
'first_name': u'myfirstname', 
'id': 1L, 
'is_active': 1, 
'is_staff': 1, 
'is_superuser': 1, 
'last_login': datetime.datetime(2010, 4, 1, 12, 31, 59), 
'last_name': u'mylastname', 
'password': u'sha1$...$...', 
'username': u'myusername'} 

>>> country = user.address.country 
>>> user.__dict__ 
{'_address': <myapp.models.address object at 0xwherever, 
'email': u'[email protected]', 
...etc} 

所以用户对象获得,其用于在相关对象上后续查找一个_address对象。

您可以使用select_related()当你第一次得到了用户甚至访问地址之前,预填充这个缓存,所以你只打了一次数据库。