Django----模型----数据库的基本操作
1、添加记录
方式一:save()
方式二(推荐):create()
2、查询记录
(1)all()
查询所有记录,返回queryset对象。
stu_list = Student.objects.all()
(2)filter()
查询符合条件的对象,返回queryset对象。
stu_list = Student.objects.filter(name = "yuan",age = 22)
(3)get()
返回与所给筛选条件相匹配的对象,返回结果有且只有一个, 如果符合筛选条件的对象超过一个或者没有都会抛出错误。返回模型类对象。 student = Student.objects.get(pk=104)
(4)first() 和 last()
分别为查询集的第一条记录和最后一条记录,返回模型类对象。
# 没有结果返回none,如果有多个结果,则返回模型对象 student = Student.objects.filter(name="刘德华").first()
(5)order_by()
对查询结果排序,返回queryset对象
# order_by("字段") # 按指定字段正序显示,相当于 asc 从小到大
# order_by("-字段") # 按字段倒序排列,相当于 desc 从大到小
# order_by("第一排序","第二排序",...)
student_list = Student.objects.filter(classmate="301").order_by("-age").all()
student_list = Student.objects.filter(classmate="301").order_by("age").all() #正序
student_list = Student.objects.filter(classmate="301").order_by("-age","id").all() # 年龄倒序,年龄一致按id进行正序
(6)exclude()
筛选条件不匹配的对象
(7)count()
查询集中对象的个数,计数 ret = Student.objects.filter(classmate="301").count()
(8)exists()
判断查询集中是否有数据,如果有则返回True,没有则返回False
(9)values() / values_list()
(10)distinct()
去重
(11)contains
说明:如果要包含%无需转义,直接写即可
# 查询姓名包含 华 的学生
Student.objects.filter(name__contains='华')
(12)startswith / endswith
查询姓名以’文’结尾的学生:
Student.objects.filter(name__endswith='文') 注意: 以上运算符都区分大小写,在这些运算符前加上i表示不区分大小写,如iexact、icontains、istartswith、iendswith.
(13)isnull
找出所有时间为空的数据:
找出时间不为空的数据:
(14)in
查询编号为1或3或5的学生:
Student.objects.filter(id__in=[1, 3, 5])
(15)比较查询
查询编号大于3的学生:
Student.objects.filter(id__gt=3)
(16)日期查询
year、month、day、week_day、hour、minute、second:对日期时间类型的属性进行运算:
(17)F 查询
之前的查询都是对象的属性与常量值比较,两个属性怎么比较呢? 答:使用F对象,被定义在django.db.models中。 语法: """F对象:2个字段的值比较"""
from django.db.models import F
# SQL: select * from db_student where created_time=updated_time;
student_list = Student.objects.filter(created_time=F("updated_time"))
(18)Q 查询
查询年龄大于20,并且编号小于30的学生:
Student.objects.filter(age__gt=20,id__lt=30) 或: Student.objects.filter(age__gt=20).filter(id__lt=30)
如果需要实现逻辑或or的查询,需要使用Q()对象结合|运算符,Q对象被义在django.db.models中。
语法:
Q(属性名__运算符=值)
Q(属性名__运算符=值) | Q(属性名__运算符=值)
查询年龄小于19或者大于20的学生,使用Q对象如下:
from django.db.models import Q student_list = Student.objects.filter( Q(age__lt=19) | Q(age__gt=20) ).all()
Q对象可以使用&、|连接,&表示逻辑与,|表示逻辑或
查询年龄大于20,或编号小于30的学生,只能使用Q对象实现:
Student.objects.filter(Q(age__gt=20) | Q(pk__lt=30))
Q对象左边可以使用~操作符,表示非not。
查询编号不等于30的学生:
Student.objects.filter(~Q(pk=30))
(19)聚合查询
使用aggregate()过滤器调用聚合函数。
聚合函数包括:Avg 平均,Count 数量,Max 最大,Min 最小,Sum 求和,被定义在django.db.models中。
查询学生的平均年龄:
from django.db.models import Sum,Count,Avg,Max,Min Student.objects.aggregate(Avg('age'))
注意:aggregate的返回值是一个字典类型,格式如下:
{'属性名__聚合类小写':值}
(20)分组查询
(21)原生查询
执行原生SQL语句, 直接跳过模型, 用原生pymysql操作
ret = Student.objects.raw("SELECT id,name,age FROM tb_student") # student 可以是任意一个模型
# 这样执行获取的结果无法通过QuerySet进行操作读取,只能循环提取 for item in ret:
print(item)
3、删除记录
方式1:模型类对象.delete()
student = Student.objects.get(id=13)
student.delete()
方式2:模型类.objects.filter().delete()
Student.objects.filter(id=14).delete()
4、修改记录
方式1:使用save()保存更新数据
方式2(推荐):update()
使用模型类.objects.filter().update(),会返回受影响的行数
Django----模型----数据库的基本操作的更多相关文章
- django模型——数据库(二)
模型--数据库(二) 实验简介 模型的一些基本操作,save方法用于把对象写入到数据库,objects是模型的管理器,可以使用它的delete.filter.all.order_by和update等函 ...
- Django模型-数据库操作
前言 前边记录的URLconf和Django模板全都是介绍页面展示的东西,也就是表现层的内容.由于Python先天具备简单而强大的数据库查询执行方法,Django 非常适合开发数据库驱动网站. 这篇开 ...
- python Django教程 之 模型(数据库)、自定义Field、数据表更改、QuerySet API
python Django教程 之 模型(数据库).自定义Field.数据表更改.QuerySet API 一.Django 模型(数据库) Django 模型是与数据库相关的,与数据库相关的代码 ...
- Django 模型(数据库)
Django 模型(数据库) ) email = models.EmailField() memo = models.TextField() def __unico ...
- Django 模型(数据库)-cmd下的操作
Django 模型是与数据库相关的,与数据库相关的代码一般写在 models.py 中,Django 支持 sqlite3, MySQL, PostgreSQL等数据库,只需要在settings.py ...
- Django框架:2、静态文件配置、form表单、request对象、pycharm链接数据库、django链接数据库、ORM框架
Django框架 目录 Django框架 一.静态文件配置 1.静态文件 2.配置方法 二.form表单 1.action属性 2.method属性 三.request对象 1.基本用法 四.pych ...
- Django模型层Meta内部类详解
Django 模型类的Meta是一个内部类,它用于定义一些Django模型类的行为特性.以下对此作一总结: abstract 这个属性是定义当前的模型类是不是一个抽象类.所谓抽象类是不会对应 ...
- django 操作数据库--orm(object relation mapping)---models
思想 django为使用一种新的方式,即:关系对象映射(Object Relational Mapping,简称ORM). PHP:activerecord Java:Hibernate C#:Ent ...
- django模型
用django时,只要用到数据库就得用到模型. 一.数据库的MTV开发模式 从MVC到MTV 所谓软件架构的MVC模式将数据的存取逻辑(Module),表现逻辑(View)和业务逻辑(Controll ...
- 【Python】django模型models的外键关联使用
Python 2.7.10,django 1.8.6 外键关联:http://www.bubuko.com/infodetail-618303.html 字段属性:http://www.cnblogs ...
随机推荐
- HuffmanTree,哈夫曼树的原理和c++实现
目录 一.什么是哈夫曼树 二.构造哈夫曼树 三.路径.编码.解码 四.代码 一.什么是哈夫曼树 哈夫曼树又称为最优树. 通过权值来构造树,权值越大,离根节点越近 经常用于无损压缩算法 用于需要优化存储 ...
- 第十六篇:jQuery基础
一.jQuery和Dom的关系 http://jquery.cuishifeng.cn/ 模块,类库 DOM/BOM/JavaScript的类库: 二.jQuery选择器 1.查找元素 DOM: 10 ...
- 基于Canvas实现的简历编辑器
基于Canvas实现的简历编辑器 大概一个月前,我发现社区老是给我推荐Canvas相关的内容,比如很多 小游戏.流程图编辑器.图片编辑器 等等各种各样的项目,不知道是不是因为我某一天点击了相关内容触发 ...
- mysql 必知必会整理—触发器[十五]
前言 现在很多都是程序用于触发的,而不是触发器了. 正文 需要MySQL 5 对触发器的支持是在MySQL 5中增加的.因此,本章内容适用于MySQL 5或之后的版本. MySQL语句在需要时被执行, ...
- 重新点亮linux 命令树————二进制安装[十一八]
前言 简单介绍一下二进制安装 正文 wget https://openresty.org/download/openresty-1.15.8.1.tar.gz tar -zxf openresty-V ...
- Flutter笔记-基础组件
图片和Icon 加载网络图片以及本地图片 Image( image: NetworkImage( "https://img-s-msn-com.akamaized.net/tenant/am ...
- 阿里云 ACK 容器服务生产级可观测体系建设实践
简介: 随着容器被越来越对企业接纳与落地,可观测成为重点.那么,让我们深入了解阿里云 ACK 容器服务生产级可观测体系建设实践,为自身业务可观测提供参考- 作者:冯诗淳(行疾) ACK 可观测体系 ...
- 技术解读 | 智能开放搜索CTR预估模型
简介:本文介绍开放搜索CTR预估模型在个性化排序中的应用与实践 如何评价搜索排序效果? 搜索是用户触达信息最简单直接的方式,是APP.网页必备的功能.如何评价并提升搜索效果一直是搜索领域的常见问题. ...
- Flink 在唯品会的实践
简介: Flink 在唯品会的容器化实践应用以及产品化经验. 唯品会自 2017 年开始基于 k8s 深入打造高性能.稳定.可靠.易用的实时计算平台,支持唯品会内部业务在平时以及大促的平稳运行.现平台 ...
- SmartNews:基于 Flink 加速 Hive 日表生产的实践
简介: 将 Flink 无缝地集成到以 Airflow 和 Hive 为主的批处理系统的技术挑战和应对方案. 本文介绍了 SmartNews 利用 Flink 加速 Hive 日表的生产,将 Flin ...