1.准备数据表:

from django.db import models

class City(models.Model):
name=models.CharField(max_length=32)
nid=models.AutoField(primary_key=True) class Author(models.Model):
name=models.CharField(max_length=32)
nid=models.AutoField(primary_key=True)
city=models.ForeignKey(to=City,on_delete=models.CASCADE) class Book(models.Model):
nid=models.AutoField(primary_key=True)
title=models.CharField(max_length=32)
author=models.ManyToManyField(to=Author) #中间表,不用写on_delete class info(models.Model):
telephone=models.IntegerField()
nid=models.AutoField(primary_key=True)
author=models.OneToOneField(to=Author,on_delete=models.CASCADE) #数据库中增加了字段author_id

2.插入数据:

models.City(name='losange').save()
models.City(name='shanghai').save() models.Book.objects.create(title='liao story')
models.Book.objects.create(title='spring')
models.Book.objects.create(title='old man and sea')
models.Book.objects.create(title='the sun rises')
models.Book.objects.create(title='cats')
models.Book.objects.create(title='lions') city=models.City.objects.first()
models.Author.objects.create(name='haimingwei',city=city)
city=models.City.objects.all()[1]
models.Author.objects.create(name='xuewen',city=city)

3.查询操作

#1.跨表多对多查询
#模型关系 城市 <-- 作者 <-- 书

#查询haimingwei写的所有书籍
#基于对象-->反向查询(按表名_set) (返回queryset)
models.Author.objects.get(name='haimingwei').book_set.values('title')
#基于queryset-->反向查询(按表名) (返回queryset)
models.Author.objects.filter(name='haimingwei').values('book__title')
#基于queryset-->正向查询(按字段) (返回queryset)
models.Book.objects.filter(author__name='haimingwei').values('title')

#查询spring这本书的作者
#基于对象-->正向查询(按字段) (返回queryset)
models.Book.objects.get(title='spring').author.values('name')
#基于queryset-->反向查询(按表名) (返回queryset)
models.Author.objects.filter(book__title='spring').values('name')
#基于queryset-->正向查询(按字段) (返回queryset)
models.Book.objects.filter(title='spring').values('author__name')

#2.跨表一对多查询 #模型关系 城市 <-- 作者 <-- 书
#查询shanghai所有的作者
#基于对象 --> 反向查询(按表名_set) (返回queryset)
models.City.objects.get(name='shanghai').author_set.values('name')
#基于queryset --> 反向查询(按表名)
models.City.objects.filter(name='shanghai').values('author__name')
#基于queryset --> 正向查询(按字段)(返回queryset)
models.Author.objects.filter(city__name='shanghai').values('name')

#查询海明威所在的城市
#基于对象 --> 正向查询 (按字段) (返回object)
models.Author.objects.get(name='haimingwei').city.name
#基于queryset --> 反向查询(按表名)
models.City.objects.filter(author__name='haimingwei').values('name')
##基于queryset --> 正向查询(按字段)
models.Author.objects.filter(name='haimingwei').values('city__name')

#3.跨表一对一查询
#模型关系 作者 <-- 作者信息

#查询手机号为123的作者
#基于对象 --> 正向查询 (按字段) (返回object)
models.info.objects.get(telephone=123).author.name
#基于queryset --> 正向查询(按字段)
models.info.objects.filter(telephone=123).values('author__name')
#基于queryset --> 反向查询(按表名)
models.Author.objects.filter(info__telephone=123).values('name')

#查询haimingwei的手机号
#基于对象 --> 反向查询 (按表名) (返回object!!!)
models.Author.objects.get(name='haimingwei').info.telephone
#基于queryset --> 正向查询(按字段)
models.info.objects.filter(author__name='haimingwei').values('telephone')
#基于queryset --> 反向查询(按表名)
models.Author.objects.filter(name='haimingwei').values('info__telephone')

#查询写old man and sea这本书作者所在的城市 -->跨三张表查询!
#models.City.objects.filter(author__book__title='old man and sea').values('name')
#models.Book.objects.filter(title='old man and sea').values('author__city__name')
#models.Author.objects.filter(book__title='old man and sea').values('city__name')

from django.db.models import Max,Avg,F,Q,Min,Count,Sum

#聚合查询 --> 返回一个字典
models.info.objects.aggregate(total=Sum('telephone'))

#分组查询 -->不管是单表还是跨表一律都是基于queryset的查询
#模型关系 城市 <-- 作者 <-- 书

#查询每个作者写的书籍总数 -->作者作为基表
models.Author.objects.values('name').annotate(each_total=Count('book__title')).values('name','each_total')
#查询每个作者写的书籍总数 -->书作为基表
models.Book.objects.values('author__name').annotate(each_total=Count('title')).values('each_total')

#查询每本书的作者个数
models.Book.objects.values('title').annotate(total=Count('author__nid'))
models.Author.objects.values('book__title').annotate(total=Count('nid'))

#查询不止一个作者的书籍
models.Book.objects.values('nid').annotate(c=Count('author__nid')).filter(c__gt=1).values('title','c')

#F查询
#比较不同字段值
models.info.objects.filter(telephone__gt=F('nid'))
models.info.objects.filter(telephone__gt=F('nid')*2)
#修改字段值
models.info.objects.update(telephone=F('telephone')*2).values('telephone')

#Q查询
#查询xuewen或海明威所写的书
models.Book.objects.filter(Q(author__name='haimingwei')|Q(author__name='xuewen')).values('title')

总结:

  • 查询返回多个对象时,返回值为queryset;
  • 基于对象反向查询时,表名_set!
  • 确定返回一个对象时,返回值为object!

Django Models 查询操作的更多相关文章

  1. django models 数据库操作

    django models 数据库操作 创建模型 实例代码如下 from django.db import models class School(models.Model): pass class ...

  2. django模型查询操作

    一旦创建好了数据模型,Django就会自动为我们提供一个数据库抽象API,允许创建.检索.更新和删除对象操作 下面的示例都是通过下面参考模型来对模型字段进行操作说明: from django.db i ...

  3. Django—models相关操作

    一.在django后台admin管理页面添加自己增加的表结构 通过终端命令:python3 manage.py makemigrations, python3 manage.py migrate 我们 ...

  4. django models数据库操作

    一.数据库操作 1.创建model表         基本结构 1 2 3 4 5 6 from django.db import models     class userinfo(models.M ...

  5. django之查询操作及开启事务

    目录 聚合查询 aggregate 聚合函数 分组查询 annotate F与Q查询 F查询 Q查询 ORM操作事务 django中开启事务 聚合查询 aggregate 操作外键字段管理数据的时候, ...

  6. Django orm查询操作

    基于双下划线查询切记!!!!正向查询按字段,反向查询按表名的小写 正向:在Book表里设置关联Obj表,Book------>Obj就是正向查询 反向:在Book表里设置关联Obj表,Obj-- ...

  7. Django ORM 查询操作

    queryset中支持链式操作 book=Book.objects.all().order_by('-nid').first() 只要返回的是queryset对象就可以调用其他的方法,直到返回的是对象 ...

  8. Django 1.10 中文文档------3.2.2 查询操作making queries

    3.2.2 查询操作 6.15章节包含所有模型相关的API解释. 后面的内容基于如下的一个博客应用模型: from django.db import models class Blog(models. ...

  9. 查询操作 -- Django从入门到精通系列教程

    该系列教程系个人原创,并完整发布在个人官网刘江的博客和教程 所有转载本文者,需在顶部显著位置注明原作者及www.liujiangblog.com官网地址. Python及Django学习QQ群:453 ...

随机推荐

  1. mysql数据库打开连接时报错:1251

    考试之前由于一直在做团队项目导致疏忽了数据库 等到今天来连接做考试的时候发现报错:1251 网上的解释以及解决方法: 今天下了个 MySQL8.0,发现Navicat连接不上,总是报错1251: 原因 ...

  2. python脚本简化jar操作命令

    本篇和大家分享的是使用python简化对jar包操作命令,封装成简短关键字或词,达到操作简便的目的.最近在回顾和构思shell脚本工具,后面一些文章应该会分享shell内容,希望大家继续关注. 获取磁 ...

  3. 用ASP.NET Core 2.1 建立规范的 REST API -- HATEOAS

    本文所需的一些预备知识可以看这里: http://www.cnblogs.com/cgzl/p/9010978.html 和 http://www.cnblogs.com/cgzl/p/9019314 ...

  4. mysql的学习笔记(三)

    1.外键约束(保持数据一致,完整.实现一对多或一对一) 父表(参照的表)和子表(有外键列的表)必须使用相同的存储引擎InnoDB,禁止使用临时表. 外键列和参照列必须具有相似的数据类型.其中数字的长度 ...

  5. MySQL系列--3.数据类型和连接查询

    1.存储引擎 数据创建,查询,更新和删除操作都是通过数据引擎来进行的.不同的存储引擎存储限制不同,支持不同的索引机制等. 查询数据库支持的存储引擎 MySQL 5.7.2支持的存储引擎有:InnoDB ...

  6. Java并发专题(三)深入理解volatile关键字

    前言 上一章节简单介绍了线程安全以及最基础的保证线程安全的方法,建议大家手敲代码去体会.这一章会提到volatile关键字,虽然看起来很简单,但是想彻底搞清楚需要具备JMM.CPU缓存模型的知识.不要 ...

  7. [转]Blue Prism Architecture

    本文转自:https://mindmajix.com/blue-prism-architecture Introduction Automation technology is widely bloo ...

  8. 【转载】Sqlserver数据库中无自增Id的情况下使用ROW_NUMBER()函数进行数据分页

    在Sqlserver数据库中,如果查询表中含有自增长Id列,一般会采用select Top的方式来数据的分页操作.而实际上很多数据表设计的时候,不一定含有自增长Id列,那么数据库没有Id自增列的时候要 ...

  9. AppStore IPv6-only审核被拒原因分析及解决方案-a

    Apple关于IPV6规定 日前,苹果公司向开发者发出提醒,公司将会修改应用商店App Store的相关规定,所有IOS应用必须包含对IPv6-only标准的支持.据悉,该规定在6月1日生效,所有提交 ...

  10. spring通知执行的顺序

    点击下载本示例相关代码 关于spring aop的具体使用,暂时不在这里讲解,后面会特定来讲解,本次主要探讨spring中通知执行的顺序. spring中通知分为以下几种: before:前置通知,在 ...