六、Django学习之基于下划线的跨表查询
六、Django学习之基于下划线的跨表查询
一对一
正向查询的例子为 已知用户名,查询用户的电话号码。反向查询例子反之。
正向查询
其中下划线前的表示表名,无下划线的表示的是Author表
1 | result = models.Author.objects.filter(name='admin').values("authorDetail__telephone",'name','age') |
反向查询
values可以不写,则去除能拿到的全部数据。filter中的双下划线表示联表
1 | result = models.AuthorDetail.objects.filter(author__name='admin').values('telephone') |
一对多
正向查询
1 | result = models.Book.objects.filter(title='第一本书').values("publishs__name") |
反向查询
1 | result = models.Publish.objects.filter(book__title='第一本书').values('name') |
多对多
正向查询
1 | obj = models.Publish.objects.filter(name='老男人出版社').values("book__title") |
反向查询
1 | obj = models.Book.objects.filter(publishs__name='老男人出版社').values('title') |
进阶使用
三表联查
查询老男人出版社出版的书的名字和作者的名字
1 | obj = models.Book.objects.filter(publishs__name='老男人出版社').values('title','authors__name') |
关于反向查询代替字段
在创建表是外键字段添加参数related_name
1 | class Book(models.Model): |
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 小康博客!
评论
TwikooWaline