我想知道多对多领域的相关名称。m2m字段位于模型“组”和“选择”之间,在组模型中定义如下:
lections = models.ManyToManyField(Lection, blank=True)
字段如下所示:
<django.db.models.fields.related.ManyToManyField object at 0x012AD690>
打印的field.__dict__
是:
{'_choices': [],
'_m2m_column_cache': 'group_id',
'_m2m_name_cache': 'group',
'_m2m_reverse_column_cache': 'lection_id',
'_m2m_reverse_name_cache': 'lection',
'_unique': False,
'attname': 'lections',
'auto_created': False,
'blank': True,
'column': 'lections',
'creation_counter': 71,
'db_column': None,
'db_index': False,
'db_table': None,
'db_tablespace': '',
'default': <class django.db.models.fields.NOT_PROVIDED at 0x00FC8780>,
'editable': True,
'error_messages': {'blank': <django.utils.functional.__proxy__ object at 0x00FC
7B50>,
'invalid_choice': <django.utils.functional.__proxy__ object
at 0x00FC7A50>,
'null': <django.utils.functional.__proxy__ object at 0x00FC7
A70>},
'help_text': <django.utils.functional.__proxy__ object at 0x012AD6F0>,
'm2m_column_name': <function _curried at 0x012A88F0>,
'm2m_db_table': <function _curried at 0x012A8AF0>,
'm2m_field_name': <function _curried at 0x012A8970>,
'm2m_reverse_field_name': <function _curried at 0x012A89B0>,
'm2m_reverse_name': <function _curried at 0x012A8930>,
'max_length': None,
'name': 'lections',
'null': False,
'primary_key': False,
'rel': <django.db.models.fields.related.ManyToManyRel object at 0x012AD6B0>,
'related': <RelatedObject: mymodel:group related to lections>,
'related_query_name': <function _curried at 0x012A8670>,
'serialize': True,
'unique_for_date': None,
'unique_for_month': None,
'unique_for_year': None,
'validators': [],
'verbose_name': 'lections'}
现在应该通过一个election实例访问该字段。所以这是由lection.group_set
完成的
但是我需要动态地访问它,所以需要从某个地方获取相关的_name属性。
Here在文档中,有一个注意事项是可以访问ManyToManyField.related_name
,但无论如何这对我的。。
很感谢你的帮助。 提前谢谢。
编辑: 是否需要将一个类放在我的所有模型之上,该类指定相关的_name属性,因此,每个模型都有一个相似的名称?比如这里?->;docs.djangoproject.com/en/dev/topics/db/models/#小心相关名称
尝试:
你粘贴的基本内容是:
您可能需要的是获取包含该字段的实际模型类:
--然后你可以:
我在过去使用过
object.yourmanagerclass.join_table
,但请注意,这将返回一个带引号的字符串相关问题 更多 >
编程相关推荐