首页 > 其他分享 >django跨表查询

django跨表查询

时间:2022-10-25 16:59:33浏览次数:76  
标签:name models related 查询 跨表 objects UserInfo django

https://blog.csdn.net/moshanghuali/article/details/103849558

一. 基于对象的跨表查询方式,常用的是符号 .

基于对象的跨表查询也分正向查询和反向查询。

由主表查从表就是反向,由从表查主表就是正向。一般来说外建放在那个表中,哪个表就是从表。

例如:

class UserInfo(models.Model):
    username=models.CharField(max_length=32)
    pwd = models.CharField(max_length=32)
    address = models.CharField(max_length=32)

class UserDetail(models.Model):
    boyfiend_name = models.CharField(max_length=32)
    phonenum = models.CharField(max_length = 11)
    user = models.ForeignKey(UserInfo,related_ name='uuu')

注意:

无论是正向查询还是反向查询,首先记住这种查询方式是基于对象的查询。

get()或者first(),last()等获得的是单个对象。

1. 正向查询:
UserDetail(从表) --> UserInfo (主表) 

UserDetail.objects.get(id=1).user.all()
UserDetail.objects.get(id=1).user.username
UserDetail.objects.get(id=1).user.pwd
2. 反向查询:
UserInfo (主表) --> UserDetail(从表)

UserInfo.objects.get(id=1).uuu.all()
#这里related_name == 表名_set,如果user外建没设置related_name的话
UserInfo.objects.get(id=1).userdetail_set.all()

# 注意反向操作的时候,由于查询出的可能是一个QuerySet。因此不可以在最后直接点.字段名。
UserInfo.objects.get(id=1).uuu.all()[0].phonenum
UserInfo.objects.filter(id=1).first().uuu.all()[0].phonenum

二. 基于双下划线的跨表查询

基于双下划线的跨表查询也分为正向查询和反向查询。

1.正向查询:查询条件字段或者查询字段在主表中。由从表查主表。
# 查询条件字段在主表中,最终查询字段值还是在从表中。
UserDetail.objects.filter(user__pwd=123).values()

# 查询字段值在主表中,查询条件字段在从表中。
UserDetail.objects.filter(phonenum=110).values('user__pwd') 
2. 反向查询:查询条件字段或者查询字段值在从表中,由主表查从表。
# 查询条件字段在从表中。
UserInfo.objects.filter(uuu__phonenum=110).values()

# 查询字段值在从表中。
UserInfo.objects.filter(username='xiao').values('uuu__phonenum')
class Department(models.Model):
 title = models.CharField(verbose_name='名称',max_length=32)
 
class UserInfo(models.Model):
 depart=models.ForeignKey(verbose_name='部门',to='Department',related_query_name="u")
 user = models.CharField(verbose_name='员工',max_length=32)
 pwd = models.CharField(verbose_name='面膜', max_length=32)

正向查询

user_object = UserInfo.objects.get(id=1)
user_object.depart

反向查询,related_query_name相当于从表的别名

depart_object = Department.objects.get(id=9)
depart_object.u_set.all()

当related_query_name和related_name同时出现时,related_query_name或覆盖related_name,你再使用related_name会报错。当related_name出现时,而related_query_name未出现。你必须使用related_name,此时在使用表名的话会报错。

在反向查询时,在没有设置related_name的时候,基于双下划线只需使用表名,而基于对象的查询方式需要使用表名_set

标签:name,models,related,查询,跨表,objects,UserInfo,django
From: https://www.cnblogs.com/regit/p/16825407.html

相关文章