11.Django数据库操作(查)
django.db.models.query.QuerySet
1.可迭代
2.可切片
官方文档:https://docs.djangoproject.com/en/1.9/ref/models/querysets/
相关API
1.get(**kwargs)
解释:返回与筛选条件相匹配的Model对象,返回结果有且只有一个。
说明:如果符合条件的对象多于一个抛出MultipleObjectsReturned异常,如果没有找到抛出DoesNotExist异常
语法:ModelName.objects.get(itemName=itemNameValue)
例子:Author.objects.get(id=1)
2.all()
解释:查询所有结果(懒加载),当查询的时候并不真实发送sql语句,用的时候才会真的去查询
语法:ModelName.objects.all()
例子:Author.objects.all(id=1)
3.filter(**kwargs)
解释:包含了与所给的筛选条件相匹配的QuerySet
语法:ModelName.objects.filter(itemName=itemNameValue)
例子:Author.objects.filter(id=1)
4.exclude(**kwargs):
解释:包含了与所给的筛选件不匹配的QuerySet,于filter正好相反
语法:ModelName.objects.exclude(itemName=itemNameValue)
例子:Author.objects.filter(id=1)
5.order_by(*fields)
解释:对查询结果进行排序
语法:ModelName.objects.all().order_by("itemName")
例子:Author.objects.all().order_by("id")
6.reverse()
解释:对查询结果反向排序
语法:ModelName.objects.all().order_by("itemName").reverse()
例子:Author.objects.all().order_by("id")
7.distinct()
解释:对查询结果去重
语法:ModelName.objects.all().distinct()
例子:Author.objects.all().distinct()
8.values(*fields)
解释:返回一个ValuesQuerySet(一个特殊的QuerySet)
说明:运行后得到的不是一系列model的实例对象,而是一个可迭代的字段序列
语法:ModelName.objects.filter(name=value).values("name","name")
例子:Author.objects.filter(id=1).values("name","id")
9.values_list(*fields)
解释:与values相似只是返回的是一个元组
语法:ModelName.objects.filter(name=value).values_list("name","name")
例子:Author.objects.filter(id=1).values_list("name","id")
10.count()
解释:返回数据库中匹配查询的对象数量
语法:ModelName.objects.filter(itemName=itemNameValue).count()
例子:Author.objects.filter(name="xiaol").count()
11.first()/last()
解释:第一条记录/最后一条记录
语法:ModelName.objects.filter(itemName=itemNameValue).first()
例子:Author.objects.filter(name="xiaol").last()
关联查询:
方法:使用两个下划线(__)可以进行关联查询
例子:查询AutherDetail的信息
语法:AuthorDetail.objects.filter(id="2").values("sex","email", "author__name")
聚合查询:需要引入from django.db.models import *
方法:使用aggreagte关键字
用法:xxx.filter(查询条件).aggregate(别名=聚合函数('聚合字段'))
语法:Author.objects.filter(name="xiaol").aggregate(myCount=Count('id'))
分组查询:需要引入from django.db.models import *
方法:使用aggreagte关键字
用法:xxx.filter(分组字段).annotate(分组后操作)
语法:Author.objects.filter(name="xiaol").annotate(myCount=Count('id'))
11.Django数据库操作(查)的更多相关文章
- Django数据库操作(增删改查)
Django数据库操作(增删改查) 创建数据库中的一个表 class Business(models.Model): #自动创建ID列 caption = models.CharField(max_l ...
- 从命令行运行django数据库操作
从命令行运行django数据库操作,报错: django.core.exceptions.ImproperlyConfigured: Requested setting DEFAULT_INDEX_T ...
- Django 数据库操作
Django 数据库操作 Django运算表达式与Q对象/F对象 1 模型查询 概述: 1 查询集:表示从数据库中获取的对象的集合 2 查询集可以有多个过滤器,通过 逻辑运算符连接 3 过滤器就是一个 ...
- django数据库操作和中间件
数据库配置 django的数据库相关表配置在models.py文件中,数据库的连接相关信息配置在settings.py中 models.py相关相关参数配置 from django.db import ...
- Django数据库操作
刚学到Django的数据库操作,把它记录下来,方便以后查看: 在Django中定义数据库表,并使用Django提供的方法来对数据库进行操作(增.删.改.查) 1.定义3个数据库表: class Gro ...
- django数据库操作-增删改查-多对多关系以及一对多(外键)关系
一.一对多(外键) 例子:一个作者对应多本书,一本书只有一个作者 model代码: class Person(models.Model); name = models.CharField('作者姓名' ...
- 转: django数据库操作-增删改查-多对多关系以及一对多(外键)关系
原文链接:http://blog.csdn.net/u010271717/article/details/22044415 一.一对多(外键) 例子:一个作者对应多本书,一本书只有一个作者 model ...
- django 数据库操作详解
Django配置使用mysql数据库 修改 settings.py 中的 DATABASES 注意:django框架不会自动帮我们生成mysql数据库,所以我们需要自己去创建. DATABASES ...
- Python Django 数据库操作
1. 建立app 在自己的工程项目目录下输入: python manage.py startapp myapp(你想建立的app名称) 建立一个叫myapp的app 这样,在你的工程项目目录下会出现一 ...
随机推荐
- android layout 布局属性
控件属性: android属性 Android功能强大,界面华丽,但是众多的布局属性就害苦了开发者,下面这篇文章结合了网上不少资料, 第一类:属性值为true或false android:layout ...
- [React] Use react-rewards to add microinteractions to React app to reward users for some actions
It's important that our users enjoy using our application or website. One way we can make it happen ...
- Weblogic OutOfMemory exception的误解 -- thread limitation
不是全部的OutofMemory exception都是内存问题... 前几天有个客户的site报了下面错误: [ERROR][thread ] Could not start thread Time ...
- PS如何制作超酷3D字效果
效果图.jpg (24.94 KB) 2008-4-4 21:46 1.打开PS 执行文件-新建-新建550X400像素空白文档 1.jpg (36.69 KB) 2008-4-4 21:46 2.输 ...
- Codeforces #263 div2 解题报告
比赛链接:http://codeforces.com/contest/462 这次比赛的时候,刚刚注冊的时候非常想好好的做一下,可是网上喝了个小酒之后.也就迷迷糊糊地看了题目,做了几题.一觉醒来发现r ...
- RAP + MOCK
前后端分离式开发的思考 目前大部分公司都实行了前后端分离开发.然而在项目开发过程当中,经常会遇到以下几个尴尬的场景: 1.前端开发依赖于后端接口数据,需要与后端接口联调才能获得数据展示,从而拖慢了开发 ...
- 1、硬件IO口配置;
对于MTK TP驱动移植一般分为六部分: 1.硬件IO口配置: 2.TP驱动移植. 3.I2C通信: 4.中断触发: 5.数据上报: 6.虚拟按键. 硬件电路: 1.GPIO配置 打开 mediate ...
- IBM Rational AppScan使用详细说明
转自:http://www.nxadmin.com/tools/675.html 本文将详细介绍Appscan功能选项设置的细节,适合E文一般,初次接触Appscan的童鞋参考阅读. Appscan是 ...
- docker教程之从一头雾水到不一头雾水(1)
一.安装docker 1.搜索docker [root@node3 ~]# yum search docker Loaded plugins: fastestmirror, langpacks Loa ...
- YUV420视频上面添加字幕
1.source_codemain.c中实现了函数draw_Font_Func(),这个函数可以直接移植到C程序中使用.zimo.h里面放的是字模转码后的数据. 2.data_yuv测试用的yuv42 ...