如何在 Django 中同时使用 prefetch_related 和 select_related?

问题描述

这是我的 Django 应用程序中 models.py 的一部分。

class User(models.Model):
    user_id = models.AutoField(primary_key=True)
    uuid = models.CharField(max_length=32)
    name = models.CharField(max_length=10)
    phone = models.CharField(max_length=20)
    created_at = models.DateTimeField(auto_Now_add=True)
    updated_at = models.DateTimeField(auto_Now=True)

        
class UserForm(models.Model):
    user = models.OnetoOneField(User,on_delete=models.CASCADE,primary_key=True)
    access_info = models.CharField(max_length=250)
    etc_comment = models.CharField(max_length=250)
    created_at = models.DateTimeField(auto_Now_add=True)
    updated_at = models.DateTimeField(auto_Now=True)


class UserAddress(models.Model):
    user_address_id = models.AutoField(primary_key=True)
    user = models.ForeignKey(User,on_delete=models.CASCADE)
    address_name = models.CharField(max_length=100)
    address_name_detail = models.CharField(max_length=100)
    address_type = models.CharField(max_length=11)
    address_coord = models.PointField()
    created_at = models.DateTimeField(auto_Now_add=True)
    updated_at = models.DateTimeField(auto_Now=True)

我正在使用 MysqL 数据库并将其链接到 django 数据库

我的问题是如何在一个查询中将所有三个数据放在一起。

据我所知,我必须使用 django 的 prefetch_relatedselect_related 方法将它们像这样组合在一起

objs = User.objects.select_related('userform').get(user_id=1)

但是,如何从三个模型类中获取它们?

如果您有任何想法,请告诉我。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...