前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >六、Django学习之基于下划线的跨表查询

六、Django学习之基于下划线的跨表查询

作者头像
Dreamy.TZK
发布2020-04-09 14:38:40
5710
发布2020-04-09 14:38:40
举报
文章被收录于专栏:小康的自留地

六、Django学习之基于下划线的跨表查询

一对一

正向查询的例子为 已知用户名,查询用户的电话号码。反向查询例子反之。

正向查询

其中下划线前的表示表名,无下划线的表示的是Author表

代码语言:javascript
复制
result = models.Author.objects.filter(name='admin').values("authorDetail__telephone",'name','age')

反向查询

values可以不写,则去除能拿到的全部数据。filter中的双下划线表示联表

代码语言:javascript
复制
result = models.AuthorDetail.objects.filter(author__name='admin').values('telephone')

一对多

正向查询

代码语言:javascript
复制
result = models.Book.objects.filter(title='第一本书').values("publishs__name")

反向查询

代码语言:javascript
复制
result = models.Publish.objects.filter(book__title='第一本书').values('name')

多对多

正向查询

代码语言:javascript
复制
obj = models.Publish.objects.filter(name='老男人出版社').values("book__title")

反向查询

代码语言:javascript
复制
obj = models.Book.objects.filter(publishs__name='老男人出版社').values('title')

进阶使用

三表联查

查询老男人出版社出版的书的名字和作者的名字

代码语言:javascript
复制
obj = models.Book.objects.filter(publishs__name='老男人出版社').values('title','authors__name')
obj = models.Publish.objects.filter(name='老男人出版社').values('book__title','book__authors__name')

关于反向查询代替字段

在创建表是外键字段添加参数related_name

代码语言:javascript
复制
class Book(models.Model):
    nid = models.AutoField(primary_key=True)
    title = models.CharField( max_length=32)
    publishDate=models.DateField()
    price=models.DecimalField(max_digits=5,decimal_places=2)  #decimal(16,2)
    publishs=models.ForeignKey(to="Publish",related_name='xx')
    authors=models.ManyToManyField(to='Author',)
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-01-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 六、Django学习之基于下划线的跨表查询
    • 一对一
      • 正向查询
      • 反向查询
    • 一对多
      • 正向查询
      • 反向查询
    • 多对多
      • 正向查询
      • 反向查询
    • 进阶使用
      • 三表联查
      • 关于反向查询代替字段
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档