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 ...
随机推荐
- JDBC详解系列(一)之流程
---[来自我的CSDN博客](http://blog.csdn.net/weixin_37139197/article/details/78838091)--- JDBC概述 使用JDBC也挺长 ...
- 通过IP来判断所在城市
1 今天的讲解什么? 如何根据ip查询出所在城市?我把博客园中收集的教程整理了一下,主要结合调用相关API,或者通过纯真数据库来解决这个问题. 2 相关介绍 2.1 这个是什么? 通过IP查询所在城 ...
- http to https
https://www.cnblogs.com/powertoolsteam/p/http2https.html
- Scrapy的日志等级和请求传参
日志等级 日志信息: 使用命令:scrapy crawl 爬虫文件 运行程序时,在终端输出的就是日志信息: 日志信息的种类: ERROR:一般错误: WARNING:警告: INFO:一般的信息: ...
- leetcode刷题笔记172 阶乘后的零
题目描述: 给定一个整数 n,返回 n! 结果尾数中零的数量. 示例1: 输入: 输出: 解释: ! = , 尾数中没有零. 示例2: 输入: 输出: 解释: ! = , 尾数中有 个零. 说明: 你 ...
- yocto-sumo源码解析(四):bitbake
1. 环境准备 按照前面几节的分享,我们已经知道了oe-init-build-env是如何建立yocto项目环境的,下面我们继续研究bitbake脚本,在这之前,因为我们选择qemuarm64为目标机 ...
- CentOS-7.x Yum Repo Mirror
一. 环境 1.1 主机信息 主机 OS Storage 备注 100.64.140.101 centos 7.6 /dev/sdb > 100GB 1.selinux disable; 2.放 ...
- Kubernetes采用CoreDNS
参考文档: kubernetes插件:https://github.com/kubernetes/kubernetes/tree/master/cluster/addons/dns/coredns 自 ...
- 第二阶段站立会议alpha版总结
一.会议过程 在完成第二次冲刺后,Alpha版本最终发布,我们对校园二手交易平台开发过程及产品存在的问题进行了激烈讨论.进行了我们的团队总结会议,会议中每个人先发表了个人对Alpha版开发过程中存在的 ...
- Docker打DB2 9.7镜像采坑相关
概况:以centos:7.2.1511镜像为基础镜像,使用docker commit方式进行构建 步骤: 运行centos7.2.1511镜像(以特权模式运行,后续内核参数修改必需参数) dock ...