Python中文
首页
教程
问答
标签
搜索
登录
注册
Django序列化程序在数据库中查询forign key id
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>我使用django序列化程序序列化了几个对象,但问题是每个序列化都从数据库中查询foerign键的id,而不是仅仅从对象中获取它</p> <pre><code>class QBAccount(CompanyModel): company = models.ForeignKey(Company) >>> from deretoapp.models import QBAccount >>> import logging >>> l = logging.getLogger('django.db.backends') >>> l.setLevel(logging.DEBUG) >>> l.addHandler(logging.StreamHandler()) >>> a = QBAccount.allobjects.all()[0] >>> from django.core import serializers >>> serializers.serialize('python', [a]) (0.000) SELECT `deretoapp_company`.`id`, ... FROM `deretoapp_company` WHERE `deretoapp_company`.`id` = 45995613-adeb-488f-9556-d69e856abe5f ; args=(u'45995613-adeb-488f-9556-d69e856abe5f',) [{'pk': u'3de881eb-8409-4089-8de8-6e24f7281f37', 'model': u'deretoapp.qbaccount', 'fields': {... 'company': u'45995613-adeb-488f-9556-d69e856abe5f' ....}}] </code></pre> <p>有没有办法在不修改django代码的情况下改变这种行为?我知道<code>a.company.id</code>将查询company表(这在理想情况下不应该发生),但是在serializer中是否有一个选项,以便它执行类似于<code>a.company_id</code>的操作而不查询数据库</p> ^{pr2}$
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>我所做的来避免额外的查询似乎也不是很有效,但是它确实做到了:将<code>select_related(...)</code>添加到原始查询集中,以便在初始查询中加载相关对象。在</p> <p>例如:</p> <pre><code>a = QBAccount.allobjects.select_related('company').all()[0] </code></pre>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
尽管Python中的所有内容都是引用,为什么Python导师在没有指针的列表中绘制字符串和整数?
1 回答
尽管python中的表达式为false,但循环仍在运行
6 回答
尽管python代码正确,但从nifi ExecuteScript处理器获取语法错误
1 回答
尽管Python在Neovim中工作得很好,但插件不能识别Neovim中的Python主机
7 回答
尽管python字典包含了大量的条目,但它并没有增长
10 回答
尽管python说模块存在,为什么我会得到这个消息?
2 回答
尽管setuptools和控制盘是最新的,但无法识别singleversionexternallymanaged
10 回答
尽管stdout和stderr重定向,但未捕获错误消息
10 回答
尽管Tensorboard的事件太大,但Tensorboard的步骤太少了
6 回答
尽管tkinter上的变量已更改,但显示未更改
1 回答
尽管try/except使用Python进行单元测试时出现断言错误
1 回答
尽管URL是sam,但仍会抛出“达到最大重定向”
5 回答
尽管url有效,Pandas仍读取url的\u csv错误
8 回答
尽管while中存在时间延迟,但LINUX线程的CPU利用率为100%(1)
6 回答
尽管x0在范围内,Scipy优化仍会引发ValueError
8 回答
尽管xpath正确,但使用selenium单击链接仍不起作用
8 回答
尽管下载了ffmpeg并设置了路径变量python,但没有后端错误
9 回答
尽管下载了i,但找不到型号“fr”
10 回答
尽管下载了plotnine包,但未获取名为“plotnine”的模块时出错
7 回答
尽管为所有行指定了权重,网格(0)仍不起作用
6 回答