【问题标题】:Django: Display many-to-many fields in the change listDjango:在更改列表中显示多对多字段
【发布时间】:2011-04-20 21:04:21
【问题描述】:

Django 不支持在更改列表中显示多对多关系中的相关对象是有充分理由的。这会导致大量的数据库命中。

但有时它是不可避免和必要的,例如在更改列表中显示与对象具有多对多关系的对象类别。鉴于这种情况,是否有人有一些经验/sn-ps 等来加快速度(考虑缓存、自定义 sql 查询......)? (我知道我可以创建一个调用object.categories.all() 的方法......但这真的很让人头疼......)。

【问题讨论】:

  • 如果您返回一个包含相关数据显示值的平面 values_list,并将每个实例缓存在您的父模型中怎么办?然后在保存父模型时连接一个信号以重置这些缓存值。

标签: sql django django-admin many-to-many django-select-related


【解决方案1】:

如果您认为更改列表中每行多一个数据库命中是不可接受的,那么您必须在此处选择模型中的 denormalization

问题是如何存储这个 ManyToMany 关系?也许您可以在CharFieldTextField 中使用同步的JSON serialized object 来序列化您需要的字段子集(例如pkname)。

但是在添加一个可能很大的列时要小心对性能的副作用,查询集的defer method 是你的朋友。

【讨论】:

    猜你喜欢
    • 2014-11-11
    • 2013-08-09
    • 1970-01-01
    • 1970-01-01
    • 2021-11-20
    • 1970-01-01
    • 2011-07-07
    • 2012-03-29
    • 2017-09-19
    相关资源
    最近更新 更多