【Django-03】模型常用的增删改查

Django Model 增删改查函数

    • QuerySet 对象
    • all()
    • filter()
    • get()
    • exclude()
    • values()
    • distinct()
    • 支持的表达式
    • 组合使用
    • 创建数据
    • 更新数据
    • 删除数据
    • F()函数
    • Q()函数

class Grade(models.Model):id = models.AutoField(verbose_name='自增id', name="id", primary_key=True)grade_name = models.CharField(verbose_name="班级名称", name="grade_name", max_length=200)age = Models.IntField()create_time = models.DateTimeField(verbose_name='创建时间',name="create_time", auto_now_add=True)  # 第一次赋值update_time = models.DateTimeField(verbose_name='最后一次更新时间',name="update_time", auto_now=True)  # 第二次赋值class Meta:db_table = "app_grade"ordering=["-update_time","create_time"]

QuerySet 对象

表示查询集,是从数据库中获取到的Model集合,集合中每个元素都是我们的Model对象

all()

queryset=Grade.objects.all()
for grade in queryset:print(grade.crade_name)

filter()

类似于sql中的where

queryset=Grade.objects.filter(grade_name ='三班')
for grade in queryset:print(grade.crade_name)

get()

返回符合要求的一条数据,只返回一条,当未找到数据或者是返回的数据超过一条都会抛出异常,因此需要做异常捕捉处理。一般查询条件用主键id,这唯一对应一条数据。

grade=Grade.objects.get(id=1)
print(grade.crade_name)

exclude()

排除符合条件的值

grade=Grade.objects.exclude(grade_name ='三班')
for grade in queryset:print(grade.crade_name)

values()

指定返回的列,相当于 select grade_name create_time from student.
返回的对象包含的数据类型是 指定表列的字典dict结构,所以代码中取值略有不同

grade=Grade.objects.values('grade_name','create_name')
for grade in queryset:print(grade["crade_name"])

distinct()

一般结合values用

grade=Grade.objects.values('grade_name').distinct()
for grade in queryset:print(grade["crade_name"])

支持的表达式

上面的查询都是用的 ‘=’ ,其实还支持的表达式有:
__gt
__gte
__lt
__lte
__in
__contains
__year
__month
__day

组合使用

一些基础的组合是可以链式调用的,不必那么死板。

grade=Grade.objects.filter(id__in=(1,3,4)).filter(name__contains='张')
for grade in queryset:print(grade.name)

创建数据

save和create都行

grade=Grade()
grade.grade_name='四班'
grade.save()#  或者grade = {"grade_name": '四班'}Grade.objects.create(**grade)

更新数据

可以用save或者update函数。 逻辑很简单:先查出来数据,再对查出来的对象修改之后再保存进去即可。

  1. 基础写法

    grade=Grade.objects.get(id=1)
    grade.grade_name='四班'
    grade.save()
    
  2. 链式写法

    grade=Grade.objects.get(id=1).update(garde_name='四班')
    
  3. 批量更新

    grade=Grade.objects.update(garde_name='四班')
    

删除数据

  1. 删除单行
    grade = Grade.objects.get(id=1)
    grade.delete()
    
  2. 删除多行
    d = Grade.objects.filter(garde__contains='四').delete()
    print(d)
    
  3. 删除全部
    d = Grade.objects.all().delete()
    

如果删除的数据中有外键,且on_delete 参数值为 CASCADE 则外键关联 主表 中的数据也会被删除

F()函数

grade = Grade.objects().all()
grade.age+=1
grade.save()

上面的语句实际的执行流程是:先从数据库查出来放在内存,赋予新的值后再更新到数据库。 改成下面的样式

	grade = Grade.objects().all()grade.age=F(age)+1grade.save()grade.refresh_from_db()#必须执行此处的刷新才能生效

实际执行流程是,直接在数据库执行update, 减少一次查询操作

Q()函数

用于执行多个where条件。 用起来比较方便,代码啥的也比较简洁,推荐使用

Grade.objects().filter(Q(grade_name=‘三班’)&Q(age__gt=30))

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/226549.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

02_Web开发基础之JavaScript

Web开发基础之JavaScript 学习目标和内容 1、能够描述Javascript的作用 2、能够使用分支结构if语句逻辑判断 3、能够使用其中一种循环语句 4、能够定义javaScript中的函数 5、能够定义javaScript中的对象 6、能够描述DOM的作用 7、能够通过DOM操作HTML标签元素及其属性 8、能够…

1.2 【应用开发】开发一个基本的Screen应用

一,Screen应用开发简述 QNX Screen图形子系统是一个图形框架,因此,使用该框架开发的应用程序在复杂性和功能上可能会有很大差异。也就是说,大多数Screen应用程序在简化后,会执行某种渲染,以便在显示器上显…

走进暄桐教室 一起观看暄桐同学作品及感受

暄桐是一间传统美学教育教室,创办于2011年,林曦是创办人和授课老师,教授以书法为主的传统文化和技艺,旨在以书法为起点,亲近中国传统之美,以实践和所得,滋养当下生活。其实,暄桐教室…

vue表单输入绑定

基础用法 你可以用 v-model 指令在表单 <input>、<textarea> 及 <select> 元素上创建双向数据绑定。它会根据控件类型自动选取正确的方法来更新元素。尽管有些神奇&#xff0c;但 v-model 本质上不过是语法糖。它负责监听用户的输入事件以更新数据&#xff0…

大O记法了解

1、概念 大O记法&#xff08;Big O notation&#xff09;是一种用于描述算法时间复杂度的一种标记法。它表示了算法在最坏情况下对输入规模的增长速度&#xff0c;或者说算法执行时间的增长速度。用大写字母O和一个函数来表示&#xff0c;定义为T(n)O(f(n))。其中&#xff0c;…

数据结构与算法—查找算法(线性查找、二分查找、插值查找、斐波那契查找)

查找算法 文章目录 查找算法1. 线性查找算法2. 二分查找算法2.1 二分查找思路分析2.2 应用实例 3. 插值查找3.1 基本原理3.2 应用实例 4. 斐波那契4.1 基本原理4.2 应用实例 5. 查找总结 在java中&#xff0c;常用的查找有四种&#xff1a; 顺序(线性)查找二分查找/折半查找插值…

使用Node.js创建接口

当使用Node.js创建接口时&#xff0c;有两种主要方式&#xff1a;使用Express框架和使用Node.js的HTTP模块。 Express框架方式&#xff1a; 总的来说&#xff0c;使用Express框架可以更快速地搭建和管理接口&#xff0c;而使用Node.js的HTTP模块则提供了更多底层控制和灵活性&…

广州华锐互动:汽车电子线束加工VR仿真培训与实际生产场景相结合,提高培训效果

随着科技的不断发展&#xff0c;虚拟现实&#xff08;VR&#xff09;技术已经逐渐渗透到各个领域&#xff0c;为企业和个人带来了前所未有的便利。在汽车制造行业中&#xff0c;线束加工作为一项关键的生产工艺&#xff0c;其质量直接影响到汽车的性能和安全。因此&#xff0c;…

基于中小微企业_个体工商户的信贷评分卡模型和用户画像(论文_专利_银行调研建模使用)

背景介绍 信用贷款是指由银行或其他金融机构向中小微企业和个体工商户提供的一种贷款产品。该贷款的特点是无需提供抵押品或担保&#xff0c;主要依据借款人的信用状况来进行评估和审批。 中小微企业和个体工商户信用贷款的申请流程相对简单&#xff0c;申请人只需要提供个人…

C++高性能服务器框架muduo,与配套书籍《Linux多线程服务端编程》解读

本章解读C开源项目 muduo 代码&#xff0c;与配套书籍《Linux多线程服务端编程》&#xff0c;均来自作者陈硕&#xff0c;是业内比较有名的大神。 目录 muduo 源码解读《Linux多线程服务端编程》笔记第1章 线程安全的对象生命周期管理第2章 线程同步精要第3章 多线程服务器的适…

【【HDMI 方块移动实验 】】

HDMI 方块移动实验 dvi_transmitter_top.v module dvi_transmitter_top(input pclk ,input sys_rst_n ,input pclk_x5 ,input video_hsync ,input video_vsync ,input …

MySQL数据库的基础概念

目录 顾名思义&#xff0c;数据库是用于存储数据的&#xff0c;那这些数据被存储在哪呢&#xff1f; 文件也能存储数据&#xff0c;那在这个基础上&#xff0c;为什么还要搞出一个数据库来存储数据呢&#xff1f; MySQL的客户端登录/退出指令、服务端的启动/关闭指令 数据…

如何查看PHP信息

创建一个 PHP 文件&#xff0c;比如 info.php&#xff0c;在其中添加以下代码&#xff1a; <?php phpinfo(); ?>访问这个文件&#xff08;例如&#xff0c;在浏览器中输入 http://localhost/info.php&#xff09;&#xff0c;它会显示 PHP 的所有配置信息。在这个页面…

【设计模式】之工厂模式

工厂模式 1.介绍 工厂模式&#xff08;创建型模式&#xff09;&#xff0c;是我们最常用的实例化对象模式&#xff0c;是用工厂方法代替new操作的一种模式&#xff1b;在工厂模式中&#xff0c;我们在创建对象时不会对客户端暴露创建逻辑&#xff0c;并且是通过使用一个共同的…

服务器挖矿木马识别与清理

一、什么是挖矿木马 挖矿木马会占用CPU进行超频运算,从而占用主机大量的CPU资源,严重影响服务器上的其他应用的正常运行。黑客为了得到更多的算力资源,一般都会对全网进行无差别扫描,同时利用SSH爆破和漏洞利用等手段攻击主机。部分挖矿木马还具备蠕虫化的特点,在主机被成…

Threejs利用着色器编写动态飞线特效

一、导语 动态飞线特效是可视化数据地图中常见的需求之一&#xff0c;鼠标点击的区块作为终点&#xff0c;从其他区块飞线至点击区块&#xff0c;附带颜色变换或者结合粒子动画 二、分析 利用创建3点来构成贝塞尔曲线&#xff0c;形成线段利用着色器材质来按照线段以及时间…

Go语言学习:第1天

一、为什么开始学go语言 我自己是做测试的&#xff0c;所测试项目使用的是go语言。开始学习go语言的原因有两个&#xff1a;一方面&#xff0c;为了更好的做好工作&#xff1b; 另一方面&#xff0c;为了提高自己的核心竞争力。 二、第1天学习到的内容 2.1 Go是怎么解决包依…

JavaScript——严格检查模式

‘use strict’ &#xff1a; 严格检查模式&#xff0c;预防JavaScript的随意性导致产生的一些问题&#xff08;必须写在JavaScript的第一行&#xff09; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title…

buildadmin:表格中实现详情按钮

其一&#xff1a;创建组件并在当前控制器中引入组件 <!-- 示例核心代码(1/3) --> <!-- 详情组件在此处使用&#xff0c;但显示与否的判断是写在组件内的 --> <Detail /><!-- 引入组件 --> import Detail from ./detail.vue其二&#xff1a;注册按钮 …

ospf 知识总结

ospf 知识总结 一、ospf的概念 - 开放式最短路径优先协议&#xff0c;是广泛使用的一种动态路由协议&#xff0c;它属于链路状态路由协议&#xff0c;是一个内部网关协议&#xff08;IGP&#xff09;&#xff0c;用于在单一自治系统&#xff08;AS&#xff09;内决策路由。 - …