django ManyToMany 使用的注意事项
2017-11-05 17:29
295 查看
使用场景一:
如果在一张表中ManayTOManay字段关联的是自身,也就是出项这样的代码:
ManyToManyField(self)
那么,你需要注意一点,当你采用add方法将一个自身对象添加到该字段时,则自动建立两方的相互关联。
例如:
有一个朋友关系的字段,多对多关联到自身,
friends = models.ManyToManyField('self')
当你采用friends .add()添加对象时,则自动建立双方的关联。
为了禁止这件事情发生,需要添加一个symmetrical参数并设置为False,参考如下:
models.ManyToManyField('self', blank=True, symmetrical=False)
使用场景二:
如果在一张表中有多个ManayTOManay字段关联到相同的另一张表中,则另一张表在反向查询时则无法准确查找,为了解决这个问题,你需要在多对多字段添加一个参数related_name 并命名一个和其它多对多字段不同的名字,例如:
models.ManyToManyField('self', related_name='user_attentions')
参考如下:
有一张表名字叫A
有一张表名字叫B
A 有多个多对多字段关联到B,其中有一个字段related_name值为user_attentions,
当B进行反向查询时,则采用B.user_attentions查询即可
如果在一张表中ManayTOManay字段关联的是自身,也就是出项这样的代码:
ManyToManyField(self)
那么,你需要注意一点,当你采用add方法将一个自身对象添加到该字段时,则自动建立两方的相互关联。
例如:
有一个朋友关系的字段,多对多关联到自身,
friends = models.ManyToManyField('self')
当你采用friends .add()添加对象时,则自动建立双方的关联。
为了禁止这件事情发生,需要添加一个symmetrical参数并设置为False,参考如下:
models.ManyToManyField('self', blank=True, symmetrical=False)
使用场景二:
如果在一张表中有多个ManayTOManay字段关联到相同的另一张表中,则另一张表在反向查询时则无法准确查找,为了解决这个问题,你需要在多对多字段添加一个参数related_name 并命名一个和其它多对多字段不同的名字,例如:
models.ManyToManyField('self', related_name='user_attentions')
参考如下:
有一张表名字叫A
有一张表名字叫B
A 有多个多对多字段关联到B,其中有一个字段related_name值为user_attentions,
当B进行反向查询时,则采用B.user_attentions查询即可
相关文章推荐
- IOS开发中使用writeToFile时的注意事项
- 关于开发中使用writeToFile时的注意事项
- 使用STRINGN_TO_NPVARIANT和STRINGZ_TO_NPVARIANT 注意的事项
- Linq to SQL Profiler使用注意事项——数据库远程请求
- 自己总结一下关联关系映射中的OneToMany,ManyToOne,单向,双向注意的事项!ps:例子
- 关于开发中使用writeToFile时的注意事项
- UITableView使用注意事项(unable to dequeue a cell with identifier)
- 使用pycharm开发多个django项目注意事项
- Linq使用中的ToList注意事项
- django 数据库增强工具 south 的安装使用和注意事项。。。
- django中ManyToManyField字段的添加操作——注意!!
- TO_DATE()函数:日期转换时使用RR格式的注意事项
- SwipeToLoadLayout使用注意事项
- Django 多表关联 存储 使用方法 ManyToManyField save
- Linq to SQL Profiler使用注意事项——无限制的结果返回
- Django的ManyToManyField(多对多)的使用以及through的作用
- html to xml:Jtidy的使用及注意事项(jtidy-r938)
- Django中使用ifram注意事项
- django使用python manage.py syncdb注意事项
- zookeeper使用注意事项 - FAILED TO WRITE PID