Django ORM多对多查询方法(自定义第三张表&ManyToManyField)
对于多对多表
-1.自定义第三张表,更加灵活
-2.ManyToManyField自动生成第3张表只能有3列数据不能自己添加。
自定义第三张表
#models.py
classBoy(models.Model):
name=models.CharField(max_length=32)
classGirl(models.Model):
name=models.CharField(max_length=32)
classLove(models.Model):
b=models.ForeignKey('Boy')
g=models.ForeignKey('Girl')
#创建联合唯一索引
#classMeta:
#unique_together=[
#('b','g'),
#]
#views.py
deftest(request):
#objs=[
#models.Boy(name='summer'),
#models.Boy(name='spring'),
#models.Boy(name='autumn'),
#]
#models.Boy.objects.bulk_create(objs,5)
#objs=[
#models.Girl(name='小于'),
#models.Girl(name='小秋'),
#models.Girl(name='小夏'),
#]
#models.Girl.objects.bulk_create(objs,5)
#查询和girl小于有关系的boy
#1通过girl表进行反向查找
obj=models.Girl.objects.filter(name='小于').first().love_set.all()
#obj=models.Girl.objects.filter(name='小于').first().love_set.select_related('b').all()
foriinobj:
print(i.b.name)
print(''.center(60,'='))
#2通过Love表进行查找
obj=models.Love.objects.filter(g__name='小于').all()
foriinobj:
print(i.b.name)
#这样进行查询性能不好,需要重新发sql请求在进行查询另外一张表中的数据
boy_list=models.Love.objects.filter(g__name='小于').values('b__name')
foriinboy_list:
print(i['b__name'])
#这样进行了优化不会重复发送sql请求,查询到的结果内是字典
boy_obj=models.Love.objects.filter(g__name='小于').select_related('b').all()
foriinboy_obj:
print(i.b.name)
#select_related('ut')相当于innerjoin先连成一张表再进行查询
returnHttpResponse('insertok....')
ManyToManyField
#models.py
fromdjango.dbimportmodels
classBoy(models.Model):
name=models.CharField(max_length=32)
#m=models.ManyToManyField('Girl')
classGirl(models.Model):
name=models.CharField(max_length=32)
m=models.ManyToManyField('Boy')
#views.py
deftest(request):
#objs=[
#models.Boy(name='summer'),
#models.Boy(name='spring'),
#models.Boy(name='autumn'),
#]
#models.Boy.objects.bulk_create(objs,5)
#objs=[
#models.Girl(name='小于'),
#models.Girl(name='小秋'),
#models.Girl(name='小夏'),
#]
#models.Girl.objects.bulk_create(objs,5)
#ManyToManyField
obj=models.Girl.objects.filter(name='小秋').first()
#增
#obj.m.add(3)
#obj.m.add(3,4)
#obj.m.add(*[1,2])
#删
#obj.m.remove(3)
#obj.m.remove(3,4)
#obj.m.remove(*[1,2])
#改
#obj.m.set([1,2,])
#boy_obj=obj.m.all()
#forrowinboy_obj:
#print(row.id,row.name)
#清除
#obj.m.clear()
#反向查在没有ManyToManyField字段的表中查
obj=models.Boy.objects.filter(name='summer').first()
girl_obj=obj.girl_set.all()
#增删改查
obj.girl_set.set([1,2,3])
forrowingirl_list:
print(row.id,row.name)
returnHttpResponse('ok')
杂交(自定义第三张表+ManyToManyField)
#modles.py
classBoy(models.Model):
name=models.CharField(max_length=32)
classGirl(models.Model):
name=models.CharField(max_length=32)
m=models.ManyToManyField('Boy',through='Love',through_fields=('b','g'))#只让其生成3张表,如果不加后面产生生成4张表
classLove(models.Model):
b=models.ForeignKey('Boy')
g=models.ForeignKey('Girl')
#views.py
deftest(request):
obj=models.Girl.objects.filter(name='小于').first()
#obj.m.add(1)#不行
#obj.m.remove(1)#不行
#obj.m.set([1,2])#不行
#obj.m.clear()#可以
#obj.m.all()#可以
#杂交的方法对获取查询方便点,还添加了清空功能
boy_obj=obj.m.all()
foriinboy_obj:
print(i.name)
以上这篇DjangoORM多对多查询方法(自定义第三张表&ManyToManyField)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。