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 SQLite(单词的添加与查询应用)
本人小白,刚接触android,为方便记忆,将平时练习的代码写下来,跟大家分享,也希望大神批评指正. 这个实例主要用到的SQLite数据库的操作,可以向数据库添加单词,查询,修改以及删除单词,描述如有 ...
- 有效的web安全信息源
杂志:hackcto ,书安 乌云知识库,91ri.org,安全脉搏(http://www.secpulse.com/) 乌云公开漏洞,乌云热点漏洞,90sec 内网渗透找90.web注入找习科, 已 ...
- vue-router 运行机制 及 底层原理
1.测试页面 index.html <!DOCTYPE html> <html lang="en"> <head> <meta chars ...
- tomcat使用redis存储共享session
在tomcat集群环境下实现session共享有几种解决方式,这里介绍一种简单的方案. 使用redis对session进行存储,配置比較简单.webserver是tomcat6 1.下载jar包: c ...
- 修改pip源为国内网站
import os,sys,platformini="""[global]index-url = https://pypi.doubanio.com/simple/[in ...
- .Net、C# 汉字转拼音,简体繁体转换方法
Visual Studio International Pack 包含一组类库,该类库扩展了.NET Framework对全球化软件开发的支持.使用该类库提供的类,.NET 开发人员可以更方便的创建支 ...
- CentOS修改IP地址及关闭/打开防火墙
1.CentOS修改IP地址: # ifconfig eth0 192.168.1.80 这样就把IP地址修改为192.168.1.80(如果发现上不了网 了,那么你可能需要把网关和DNS也改一下,后 ...
- PHP curl post header
第三方教程推荐:https://www.cnblogs.com/CHEUNGKAMING/p/5717429.html
- Linux系统字符集乱码问题
假设你在安装Linux的过程中就选择了中文.可能能够省去步骤1.2.反之.假设你先安装了英文环境,而后希望它支持中文,则能够1.2步 1.首先在linux中安装中文包安装中文简体包rpm -ivh k ...
- APPLE ID随意转区到US或者HK.不需要信用卡
看到论坛有封釉想去US 或者HK 的商店下载大陆商店没有的APP.(比如 Tumblr) 但是现在在手机上或者是网页管理apple id 更改地区,需要输入付款信息. 现在教大家利用旧版的icloud ...