数据库 – Django:如何为异构数据类型树建模?
发布时间:2020-05-22 12:00:28 所属栏目:MsSql 来源:互联网
导读:我需要在我的数据库中存储树数据结构,我计划使用 django-treebeard或 django-mptt.我的混淆源是每个节点可能是三种不同的可能类型之一:根节点将始终是类型A实体,叶节点是C类实体,其间的任何东西都是B类实体.我想知道模拟这种情况的最佳方法. 更新:我首先尝
|
我需要在我的数据库中存储树数据结构,我计划使用 django-treebeard或 django-mptt.我的混淆源是每个节点可能是三种不同的可能类型之一:根节点将始终是类型A实体,叶节点是C类实体,其间的任何东西都是B类实体.我想知道模拟这种情况的最佳方法. 更新:我首先尝试了模型继承,我认为这可能是最好的方法.不幸的是,django-treebeard的公共API实际上并不是为处理这个而设计的.我最终得到它与GenericForeignKey一起工作.非常感谢您的回答. 解决方法如何使用模型中的 generic relation将树结构保存到它所代表的节点的内容对象中?from django.db import models
from django.contrib.contenttypes.models import ContentType
from django.contrib.contenttypes import generic
class Node(models.Model):
content_type = models.ForeignKey(ContentType)
object_id = models.PositiveIntegerField()
object = generic.GenericForeignKey('content_type','object_id')
在检索完整树的内容对象时,这可能会导致大量查询,但是有减少所需查询数量的ways and means. # Assuming mptt,as I'm not familiar with treebeard's API # 1 query to retrieve the tree tree = list(Node.tree.all()) # 4 queries to retrieve and cache all ContentType,A,B and C instances,respectively populate_content_object_caches(tree) (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- SQL中ENUM列的大小?
- SQL Server 字符串非空判断实现方法
- SQL2005重新生成索引的的存储过程 sp_rebuild_index font c
- 数据库 – prolog中数据管理的最佳实践
- 如何在SQL Server 2005中创建禁用的触发器?
- SQL Server 日期相关资料详细介绍
- Linq to SQL或Entity Framework for Enterprise ASP.NET MV
- sql-server – 如何更改SQL Server中的最大服务器内存
- sql-server – 什么时候应该指定PAD_INDEX?
- 主键的SQL Server BIGINT或DECIMAL(18,0)
推荐文章
站长推荐
- ibm-domino – Domino Admin:如何从Domino控制台
- sql-server – 如何使用过程保存byte []?
- MYSQL事务回滚的2个问题分析
- 在不使用DBCC的情况下确定每个SQL表的页数
- sql-server – 仅适用于Enterprise Edition的SQL
- 数据从MySQL迁移到Oracle 需要注意什么
- sql-server – 从数据库中获取上述普通学生
- sql – 在ORACLE中创建表时如何限制INTEGER的长度
- sql-server – 下载SQL Server Management Studi
- sql-server – 当我内联变量时,为什么SQL Server
热点阅读
