sql跨表查询_白话django之ORM的查询语句

00edf4143e811752337e62a668684ef0.png

教程源码:z991/django_turital

在日常开发中,数据库的增删改查(CDUR)中,查询需求偏多,所以查询的语法比增删改操作多得多,尤其是跨表关联查询,可以让代码精简很多年。

直接上代码吧,我是直接在上次写的的视图函数中改写的。

def orm_test(request):"""增加操作"""# 新增一个名字为1901的一个班级,create是新增方法,里面可以接受多个字段参数# Class.objects.create(name="1901")# 同时新增一个学生和班级操作# 新增一个班级名称为1903的班级,返回一个班级实例# cls_instance = Class.objects.get(name="1903")# stu_info左边的key要和Student模型字段对应上,因为cls是外键,所以要对应一个班级的实例# stu_info = {#     "name":"XIAOmei",#     "age": "24",#     "score":"88",#     "email": "1333@qq.com",#     "introduce": "假如你是xiaomei",#     "cls": cls_instance# }# Student.objects.create(**stu_info)"""修改操作"""# 将名字为1901的班级名称改为1901_xiu,filter为过滤,支持多个参数,update是更新方法,支持多个参数# Class.objects.filter(name="1901").update(name="1901_xiu")"""删除操作"""# 将名字为1901_xiu的班级删除掉,delete是删除方法# Class.objects.filter(name="1901_xiu").delete()"""查询操作"""# 查询单条,get返回实例,如果查询结果没有回报错,# filter查询返回的结果是多个实例的列表,# instance = Student.objects.get(pk=1)#instance = Student.objects.filter(pk=1).first()# 查询多条,返回queryset类型(多个查询结果实例的列表) 可以被迭代# queryset = Student.objects.all() ## for stu in queryset:#学生的姓名 学生的年龄 学生的分数#     print(stu.name,stu.age,stu.score)#对查询集结果进行切片,取第0个到第4个,和列表的切片一样# queryset = Student.objects.filter().all()[:5] # limit 语句# print(queryset.query) # 返回执行的sql语句# 精准查找 两条语句作用一样,查询姓名位小美的学生,结果返回查询集# queryset = Student.objects.filter(name='小美')# queryset = Student.objects.filter(name__exact='小美')# 忽略大小写# queryset = Student.objects.filter(name__iexact='xiaomei')# 模糊查询# queryset = Student.objects.filter(name__contains='xiao') # 不忽略大小写# queryset = Student.objects.filter(name__icontains='xiao') # 忽略大小写# 正则匹配法# queryset = Student.objects.filter(name__regex='^x')# queryset = Student.objects.filter(name__iregex='^x')# 大于 小于# queryset = Student.objects.filter(age__gt=17, age__lt=19)# in 一个集合中的所有# queryset = Student.objects.filter(age__in=(18,17,16))# queryset = Student.objects.all().order_by('age') 升序# queryset = Student.objects.all().order_by('-age') #升序# queryset = Student.objects.all().order_by('-age','id') #升序# for stu in queryset:#     print stu.age,stu.id# 指定字段查询# 第一种# queryset = Student.objects.values('name','age').all()# 第二种# queryset = Student.objects.values_list('name','age','score').all()# 连表查询# 第一种# queryset = Student.objects.all()# for stu in queryset:#     print stu.name,stu.cls.id,stu.cls.name# 第二种 : 牛逼的双下划线(跨表),可以用多个双下划线跨多张表# 语句功能是查询学生表中所有学生的姓名和学生所在班级的名称# cls__name 是cls双下划线name,cls 是Student中的cls字段,name是班级表中的name字段# queryset = Student.objects.values('name','cls__name').all()# 查询一个班级所有学生,执行两次sql语句# cls1 = Class.objects.get(name='1701')# queryset = Student.objects.filter(cls=cls1)# 查询一个班级所有学生,执行一次sql语句# queryset = models.Student.objects.filter(cls__name='1903').all().values('name','cls__name')# 查询一个班级所有学生,起始表从班级表开始查询,反向查询# stu_cls 是学生表中外键的别名# queryset = Class.objects.get(name='1903').stu_cls.all()# 按照分数查询 大于90分# queryset = Student.objects.filter(score__gt=90).all()return HttpResponse('数据库操作成功')

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

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

相关文章

java对象怎么创建_java对象是怎么创建出来的

1.使用new关键字这是最常见也是最简单的创建对象的方式了。通过这种方式,我们可以调用任意的构造函数(无参的和带参数的)。Employee emp1 new Employee();0: new #19 // class org/programming/mitra/exercises/Employee3: dup4: invokespecial #21 // Method org/…

看不懂论文代码怎么办_学位论文中的公式排版(制表位+mathtype+域)

写在前面为什么把公式排版单独拉出来写一篇文章呢?因为公式排版实在是太难了。公式居中标号右对齐,简直反人类好么。在学校期间一直寻找方便的公式排版自动编号方法,但搜索出来的大多只是用到了制表位,公式标号还要自己敲。最后毕…

利用trunk实现vlan内通信_实现不同VLAN间通信——单臂路由

单臂路由是一种实现不同VLAN间通信的技术,其方法是在虚拟机内接口上配置虚拟子接口。该技术是一种应急技术,仅仅用于网络预算不足,无力购买三层交换机,或者网络规模很小的情况下使用。一、实验路由器只需要一个端口和交换机(二层)…

java dispatchevent_java事件处理机制

java中的事件机制的参与者有3种角色:1.event object:就是事件产生时具体的“事件”,用于listener的相应的方法之中,作为参数,一般存在与listerner的方法之中2.event source:具体的接受事件的实体&#xff0…

eq值 推荐算法_C++实现十种排序算法

十种排序算法&#xff1a;选择排序插入排序冒泡排序希尔排序快速排序的三种实现方法归并排序堆排序&#xff08;大顶堆&#xff09;计数排序基数排序&#xff08;待实现&#xff09;桶排序&#xff08;待实现&#xff09;#include <bits/stdc.h> using namespace std; vo…

python读取tiff文件进行波段计算_python+tifffile之tiff文件读写方式

背景使用python操作一批同样分辨率的图片&#xff0c;合并为tiff格式的文件。由于opencv主要用于读取单帧的tiff文件&#xff0c;对多帧的文件支持并不好。通过搜索发现了两个比较有用的包&#xff1a;TiffCapture和tifffile。两者都可用pip安装。其中前者主要用于读取tiff文件…

java 线程停止在那个为止_java停止线程

本文将介绍jdk提供的api中停止线程的用法。停止一个线程意味着在一个线程执行完任务之前放弃当前的操作&#xff0c;停止一个线程可以使用Thread.stop()方法&#xff0c;但是做好不要使用它&#xff0c;它是后继jdk版本中废弃的或者将不能使用的方法&#xff0c;大多数停止一个…

java中的action是指什么_Struts2【开发Action】知识要点

前言前面Struts博文基本把Struts的配置信息讲解完了.....本博文主要讲解Struts对数据的处理Action开发的三种方式在第一次我们写开发步骤的时候&#xff0c;我们写的Action是继承着ActionSupport类的...为啥我们继承了ActionSupport类呢&#xff1f;下面我就会讲解到继承Action…

hql 查询条件 set集合_Redis从入门到深入-Sorted_set的value

1. sorted_set 类型新的存储需求&#xff0c;数据排序有利于数据的有效展示&#xff0c;需要提供一种可以根据自身特征进行排序的方式需要的存储结构&#xff1a;新的存储模型&#xff0c;可以保存可排序的数据sorted_set类型&#xff1a;在set的存储结构基础上添加可排序字段2…

pdm生成java_PowerDesigner通过SQL语句生成PDM文件并将name和comment进行互相转换

本篇文章主要介绍了PowerDesigner通过SQL语句生成PDM文件并将name和comment进行互相转换 超详细过程(图文)&#xff0c;具有一定的参考价值&#xff0c;感兴趣的小伙伴们可以参考一下1.软件准备软件&#xff1a;Navicat 11.1&#xff0c;Powerdesigner 152.安装步骤第一步&…

python逐步回归筛选变量_Python实现逐步回归(stepwise regression)

逐步回归的基本思想是将变量逐个引入模型&#xff0c;每引入一个解释变量后都要进行F检验&#xff0c;并对已经选入的解释变量逐个进行t检验&#xff0c;当原来引入的解释变量由于后面解释变量的引入变得不再显著时&#xff0c;则将其删除。以确保每次引入新的变量之前回归方程…

java里面如何加入高级的东西_如何成为一名Java高级架构师

近些年来互联网快速发展&#xff0c;现阶段的数据量和高并发的诉求&#xff0c;引起了不少传统的技术人员的力不从心&#xff0c;企业愈发关注到了系统架构的重要性&#xff0c;既需要掌控整体又需要洞悉局部瓶颈并依据具体的业务场景给出解决方案的领导型人物——Java架构师应…

mysql获取最好成绩对应数据的其他项_开源数据同步神器——canal

前言如今大型的IT系统中&#xff0c;都会使用分布式的方式&#xff0c;同时会有非常多的中间件&#xff0c;如redis、消息队列、大数据存储等&#xff0c;但是实际核心的数据存储依然是存储在数据库&#xff0c;作为使用最广泛的数据库&#xff0c;如何将mysql的数据与中间件的…

java怎么使用floor_Java floor() 方法

floor() 方法可对一个数进行下舍入&#xff0c;返回给定参数最大的整数&#xff0c;该整数小于或等给定的参数。语法该方法有以下几种语法格式&#xff1a;double floor(double d)double floor(float f)参数double 或 float 的原生数据类型。返回值返回 double 类型数组&#x…

python外部库是什么_如何使用Portable Python安装外部库?

由于管理员权限,我无法在我的机器上安装Python,但我成功下载/打开了Portable Python.我在Windows 7 64位机器上.我怎样才能使用以前的外部库,比如Numpy或Gmpy&#xff1f;解决方法:easy_install正在尝试从源代码安装. gmpy和gmpy2是C扩展,需要兼容的C编译器和其他库(GMP;以及gm…

java创建目录时带权限_java – 无法在外部存储中创建目录,尽管权限显然设置正确...

我有在我的清单文件中,但是尝试创建一个目录时我失败了Log.d(LOG_STRING, android.os.Environment.getExternalStorageState() );java.io.File folder new java.io.File(Environment.getExternalStorageDirectory() java.io.File.separator "test");boolean succe…

window访问不到linux的activemq_springboot整合开源项目测试拦截接口访问的频率

本节目标本篇文章主要是介绍以下springboot整合开源项目&#xff0c;实现反爬虫接口防刷的demo&#xff0c;额外的介绍一下axios的基本用法&#xff1b;所以本篇文章阅读起来相对轻松。OK&#xff0c;下面开始整合.引入项目依赖cn.keking.project kk-anti-reptile …

java 数据库外键查询_oracle中查询所有外键引用到某张表的记录

其实查找这篇文章 我主要用的sql 是这句 select * from user_cons_columns t where t.constraint_name like FK_CTS_CONT_REINS__CRR;起因&#xff1a;系统测试的时候发现如果某条记录已经被引用了&#xff0c;这个时候删除这条记录会引起数据不一致&#xff0c;系统会报错。…

sql server限制查询条数_18. Django 2.1.7 查询集 QuerySet

上一篇Django 2.1.7 模型 - 条件查询 F对象 Q对象 聚合查询讲述了关于Django模型的介绍F对象、Q对象、聚合查询等功能。不管什么查询&#xff0c;返回的结果都基本是查询集QuerySet&#xff0c;如下&#xff1a;In [16]: MiddlewareInfo.objects.all()Out[16]: 1)>, 2)>,…

python文件传输socket_树莓派采用socket方式文件传输(python)

两个树莓派&#xff0c;在同一个局域网内&#xff0c;传输文件&#xff0c;采用socket方式。client端代码&#xff1a;import socketimport osimport hashlibclient socket.socket() # 生成socket&#xff0c;连接serverip_port ("192.168.137.210",12346) # server…