1.基于对象的正向查询和反向查询

python---django中orm的使用(1)中也提到了正向和反向查找

表:一对多  书籍和出版社

class Book(models.Model):
title = models.CharField(max_length=)
authors = models.ManyToManyField(Author)
publisher = models.ForeignKey(Publisher)
publication_date = models.DateField()
price=models.DecimalField(max_digits=,decimal_places=,default=)
def __str__(self):
return self.title

Book(多)

class Publisher(models.Model):
name = models.CharField(max_length=, verbose_name="名称")
address = models.CharField("地址", max_length=)
city = models.CharField('城市',max_length=)
state_province = models.CharField(max_length=)
country = models.CharField(max_length=)
website = models.URLField() class Meta:
verbose_name = '出版商'
verbose_name_plural = verbose_name def __str__(self):
return self.name

出版社(一)

正向查询:

from blog import models

def data_oper(req):
obj = models.Book.objects.filter(id=)[]
print(obj.publisher.name)
print(obj.publisher.city)
#正向查询,正常查找

反向查询:

from blog import models

def data_oper(req):
obj = models.Publisher.objects.filter(id=)[]
print(obj.book_set.all().values("title").distinct()) #_set是一个queryset集合
#反向查找,需要加上_set

上面正向反向都是基于对象的查询

2.双下划线(__)

双下划线(__)之单表条件查询
models.Book.objects.filter(id__lt=,id_gt=)获取id大于1,小于10的值   and

models.Book.objects.filter(id__in=[,,])获取id在11,,13中的数据
models.Book.objects.exclude(id__in=[,,]) not in models.Book.objects.exclude(title__contains="ven")  #contains类似于like模糊查询
models.Book.objects.exclude(title__icontains="ven") #icontains大小写不敏感
models.Book.objects.exclude(title__startwith="p")

models.Book.objects.filter(id__range=[,])获取在1-10之间的数据

......像:
字段名__isnull  判断字段是否为空
双下划线(__)之关联表条件查询

一对多,多对多没有区别

正向查询
models.Book.objects.filter(title="fsa").values("publish__name")
models.Book.objects.filter(publish__name="ffa出版社").values("title") 反向查询
models.Publish.objects.filter(book__title="XX书",book__id=).values("name").distinct()
....

关联查询,表之间需要有约束,外键,或者ManyToManyField。不能随便将无关表关联

3.聚合查询 aggregate(*args,**kwargs)和分组查询annotate(*args,**kwargs)(了解)

都属于聚合函数

聚合查询是在查询结果集上进行操作,只有一个结果

分组查询是根据条件对结果进行分组,然后对应每个分组,来进行操作,有多个结果

from django.db.models import Avg,Min,Sum,Max  #导入聚合函数

聚合查询aggregate

models.Book.objects.all().aggregate(Avg("price"),Min("price"),Max("price"))

分组查询annotate:分组条件放在values中

models.Book.objects.values("authors_name").annotate(Sum("price"))#对每个作者分组

4.F和Q查询(重点)

需求引入:

将所有商品价格增加20

models.Book.objects.all().update(price="price"+20)#错误,update不能对某列进行运算,可以直接赋值

解决方法,循环每个对象,单个修改,或者迭代,或者使用F

F查询:用来对某一列值进行操作

from django.db.models import F

def data_oper(req):
models.Book.objects.all().update(price=F("price")+)
     models.Book.objects.all().update(price=F("title")+'tt')

Q查询:

前面filter()条件过滤,要么是单字段,或者and

Q:可以封装关键字查询,多关键字查询

from django.db.models import Q

def data_oper(req):
models.Book.objects.filter(id=)[]
print(obj) #打印对象的地址(若无__str__) models.Book.objects.filter(Q(id=)|Q(title="php"))[] #or
print(obj) models.Book.objects.filter(Q(price_gt=) & (Q(id=)|Q(title="php")))[] #and和or
print(obj)
    
     models.Book.objects.filter(Q(price_gt=50) & (Q(id=3)|Q(title="php")),color="yellow")[0] 
      可以把Q对象和关键字查询一起使用,但是一定要把Q对象放在关键字查询前面

        结果是列表,包含所有结果

或者可以使用:

q =Q()
q.connector = "OR"
q.children.append(('id',))   #注意这里是元组
q.children.append(('title','php'))
models.Book.objects.filter(q)

python---django中orm的使用(2)的更多相关文章

  1. Django中ORM介绍和字段及其参数

    ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描述 ...

  2. Django中ORM介绍和字段及字段参数 Object Relational Mapping(ORM)

    Django中ORM介绍和字段及字段参数   Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简 ...

  3. Django 中ORM 的使用

    一:Django 中 orm 的使用 1:手动新建一个数据库 2 :告诉Django连接哪个数据库 settings.py里配置数据库连接信息: #数据库相关的配置项 DATABASES ={ 'de ...

  4. 关于Django中ORM数据库迁移的配置

    Django中ORM数据库迁移配置 1,若想将模型转为mysql数据库中的表,需要在settings中配置: DATABASES = { 'default': { 'ENGINE': 'django. ...

  5. Django中ORM的使用

    Django中ORM的使用 ORM orm(object-relation-mapping)对象关系映射,即用对象来表示关系数据库中的表: 类 --> 表, 对象-->一行数据 对象的属性 ...

  6. Django中ORM对数据库的增删改查

    Django中ORM对数据库数据的增删改查 模板语言 {% for line in press %} {% line.name %} {% endfor %} {% if 条件 %}{% else % ...

  7. 6月20日 Django中ORM介绍和字段、字段参数、相关操作

    一.Django中ORM介绍和字段及字段参数 二.Django ORM 常用字段和参数 三.Django ORM执行原生SQL.在Python脚本中调用Django环境.Django终端打印SQL语句 ...

  8. Django中ORM实际应用

    1. Django中ORM的使用 1. 手动新建一个数据库 2. 告诉Django连接哪个数据库 settings.py里面配置数据库连接信息: # 数据库相关的配置项 DATABASES = { ' ...

  9. Python Django中QQ邮箱授权码问题

    Python Django中QQ邮箱授权码问题 系统及软件版本如下: Ubuntu Kylin 16.04 Python 3.5.1 Django 1.9.7 PyCharm Community Ed ...

  10. Django中ORM的聚合索引

    Django中ORM的聚合索引   在Django中,聚合函数是通过aggregate方法实现的,aggregate方法返回的结果是一个字典 在使用时需要先导入模块from django.db.mod ...

随机推荐

  1. 微信小程序之用户信息授权 wx.getUserInfo

    用户授权 <button open-type="getUserInfo" bindgetuserinfo='getUser'>授权用户信息</button> ...

  2. VS Code使用Git管理代码

    Visual Studio Code(简称VS Code)是一个轻量级且强大的代码编辑器,后台是微软,支持Windows.Mac和Linux操作系统,拥有丰富的插件生态系统,可通过安装插件来支持C++ ...

  3. LeetCode Letter Combinations of a Phone Number (DFS)

    题意 Given a digit string, return all possible letter combinations that the number could represent. A ...

  4. Spring学习(十九)----- Spring与WEB容器整合

    首先可以肯定的是,加载顺序与它们在 web.xml 文件中的先后顺序无关.即不会因为 filter 写在 listener 的前面而会先加载 filter.最终得出的结论是:listener -> ...

  5. 使用unity3d和tensorflow实现基于姿态估计的体感游戏

    使用unity3d和tensorflow实现基于姿态估计的体感游戏 前言 之前做姿态识别,梦想着以后可以自己做出一款体感游戏,然而后来才发现too young.但是梦想还是要有的,万一实现了呢.趁着p ...

  6. 转载别人的一篇关于git的文章

    转载网址:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000

  7. Harbor 学习分享系列1 - centos7.4安装harbor1.5.2

    centos7.4安装harbor1.5.2 前言 本系列分享将Harbor有关教程:分享形式会以百度云盘的形式进行分享,主要教程将以markdown格式进行分享:建议使用markdownpad2这款 ...

  8. EOS开发基础之五:使用cleos命令行客户端操作EOS——智能合约之Exchange

    先回答一下上一节中留下的问题,为什么我就看不到eosio这个账户中的钱呢?我明明为它create了很多token啊. 对,你是create了,但是没有issue啊.create了1000000000 ...

  9. Alpha 冲刺报告模板

    Alpha 冲刺报告模板 Deadline: 十分钟左右站立会议,控制好时间,不要在此会议上讨论细节问题. 每组一份博客,组内共享,每人都需提交. 模板 队名:xxx 组员1(组长) 今天完成了哪些任 ...

  10. webpack 学习笔记 (一)

    webpack 作为当下前端前沿最受欢迎的打包工具,作为一个前端开发人员是很有必要去了解下它的. 题外话: npm i -D 是 npm install  --save-dev的简写,是安装模块并保存 ...