Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/67.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mysql sql&;django:在数据库级别进行聚合_Mysql_Django_Django Models - Fatal编程技术网

Mysql sql&;django:在数据库级别进行聚合

Mysql sql&;django:在数据库级别进行聚合,mysql,django,django-models,Mysql,Django,Django Models,您好,我的模型出现以下情况: class Package(models.Model): name class SetOfItems(models.Model) name class Item(models.Model): package(FK) setofitems(FK) 我试图解决的问题是简化SetOfItems中的查询。例如,如果我需要从SetOfItems获取包名,我需要编写如下内容 SetOfItems.objects.values('item__

您好,我的模型出现以下情况:

class Package(models.Model):
    name

class SetOfItems(models.Model)
    name

class Item(models.Model):
    package(FK)
    setofitems(FK)
我试图解决的问题是简化SetOfItems中的查询。例如,如果我需要从SetOfItems获取包名,我需要编写如下内容 SetOfItems.objects.values('item__-package__-name'),实际上在管理站点中不起作用(例如,如果我在那里创建了一个额外的字段)

因此,我想要的是在SetOfItem模型中存储有关包的信息,而不建立直接关系(因为我认为,如果我将FK放在那里,数据完整性将受到影响,例如,可能会在项目中有一个包,而在SetOfItems中有另一个包)


所以,也许有可能有SQL视图,或者类似的东西。。。是否要从其他表中自动预填充表列?还是别的什么?

项是包和集合项之间多对多关系中的直通表。因此,您应声明如下:

class SetOfItems(models.Model):
    packages = models.ManyToManyField(Package, through='Item')

这根本不会改变您的实际表结构,但它允许您执行
my_package.setofitems.all()

如果我想在setofitems Admin中显示包,这将引发很多查询您是说在changelist中?如果您担心这一点,请覆盖
get\u queryset
以获取使用
prefetch\u related
获取所有包的查询集。