python---django中orm的使用(2)
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)的更多相关文章
- Django中ORM介绍和字段及其参数
ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描述 ...
- Django中ORM介绍和字段及字段参数 Object Relational Mapping(ORM)
Django中ORM介绍和字段及字段参数 Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简 ...
- Django 中ORM 的使用
一:Django 中 orm 的使用 1:手动新建一个数据库 2 :告诉Django连接哪个数据库 settings.py里配置数据库连接信息: #数据库相关的配置项 DATABASES ={ 'de ...
- 关于Django中ORM数据库迁移的配置
Django中ORM数据库迁移配置 1,若想将模型转为mysql数据库中的表,需要在settings中配置: DATABASES = { 'default': { 'ENGINE': 'django. ...
- Django中ORM的使用
Django中ORM的使用 ORM orm(object-relation-mapping)对象关系映射,即用对象来表示关系数据库中的表: 类 --> 表, 对象-->一行数据 对象的属性 ...
- Django中ORM对数据库的增删改查
Django中ORM对数据库数据的增删改查 模板语言 {% for line in press %} {% line.name %} {% endfor %} {% if 条件 %}{% else % ...
- 6月20日 Django中ORM介绍和字段、字段参数、相关操作
一.Django中ORM介绍和字段及字段参数 二.Django ORM 常用字段和参数 三.Django ORM执行原生SQL.在Python脚本中调用Django环境.Django终端打印SQL语句 ...
- Django中ORM实际应用
1. Django中ORM的使用 1. 手动新建一个数据库 2. 告诉Django连接哪个数据库 settings.py里面配置数据库连接信息: # 数据库相关的配置项 DATABASES = { ' ...
- Python Django中QQ邮箱授权码问题
Python Django中QQ邮箱授权码问题 系统及软件版本如下: Ubuntu Kylin 16.04 Python 3.5.1 Django 1.9.7 PyCharm Community Ed ...
- Django中ORM的聚合索引
Django中ORM的聚合索引 在Django中,聚合函数是通过aggregate方法实现的,aggregate方法返回的结果是一个字典 在使用时需要先导入模块from django.db.mod ...
随机推荐
- Nuxt 开发 - 项目初始化
Nuxt是基于Vue的一个应用框架,采用服务端渲染(SSR),可以让用户的Vue单页面应用(SPA)也可以有利于SEO. 项目初始化 参考:https://zh.nuxtjs.org/guide/in ...
- 使用不同的方法计算TF-IDF值
摘要 这篇文章主要介绍了计算TF-IDF的不同方法实现,主要有三种方法: 用gensim库来计算tfidf值 用sklearn库来计算tfidf值 用python手动实现tfidf的计算 总结 之所以 ...
- 【Orleans开胃菜系列1】不要被表象迷惑
[Orleans开胃菜系列1]不要被表象迷惑 /** * prism.js Github theme based on GitHub's theme. * @author Sam Clarke */ ...
- 虚拟机console最小化安装操作系统图文
1. 概述2. 安装操作系统2.1 交互界面2.2 内核镜像解压等初始化2.3 磁盘发现2.4 硬件支持告警3. 开始安装3.1 语言选择3.2 键盘选择3.3 服务器类型3.4 配置主机名3.5 时 ...
- 做游戏的小伙伴们注意了,DDoS还可以这样破!
欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由腾讯游戏云发表于云+社区专栏 作者:腾讯DDoS安全专家.腾讯云游戏安全专家haroldchen 摘要:在游戏出海的过程中,DDoS攻 ...
- Linux 第三周 学习笔记和实验
姬梦馨 原创博客 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 常用调试参数 r(run) 开始运行程 ...
- 软件项目第一次sprint评分表
- [财务知识]IFRS9
浅谈IFRS9 2018-07-10 23:15信用/收益 原创申明 本文原创作者为金融监管研究院助理研究员李健,未经授权谢绝转载.引用.抄袭. 引言 2018年6月6日,财政部会计司发布了“关于就& ...
- linux 修改终端颜色
要想修改终端的颜色,可以使用修改PS1环境变量的方式,也可以通过命令setterm来进行设置. 一.PS1 转自:修改linux终端命令行颜色 1.PS1 要修改linux终端命令行颜色,我们需要用到 ...
- OneZero第二周第二次站立会议(2016.3.29)
会议时间:2016年3月29日 13:05~13:16 会议成员:冉华,张敏,王巍,夏一鸣. 会议目的:汇报前一天工作,全体成员评论,确定会后修改内容或分配下一步任务. 会议内容:以下是会议插图 1 ...