首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Django(17)orm查询操作

前言 查找是数据库操作中一个非常重要的技术。查询一般就是使用filter、exclude以及get三个方法来实现。我们可以在调用这些方法的时候传递不同的参数来实现查询需求。...在ORM层面,这些查询条件都是使用field+__+condition的方式来使用的。以下将那些常用的查询条件来一一解释。 查询条件 exact 使用精确的=进行查找。...QuerySet.query QuerySet.query:query可以用来查看这个ORM查询语句最终被翻译成的SQL语句。...因此如果你的查询语句是通过get来获取数据的,那么就不能使用query,因为get返回的是满足条件的ORM模型,而不是QuerySet。...根据关联的表进行查询 假如现在有两个ORM模型,一个是Article,一个是Category。

1.1K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Django的ORM操作-查询数据

    数据库的查询需要使用管理器对象进行 通过mymodel.objects管理器方法调用查询对象 方法 说明 all() 查询全部记录,返回QuerySet查询对象 get() 查询符合条件的单一记录 filter...Mymodel中所有的数据等同与数据库中的select * from table,返回QuerySet容器对象,内部存放MyModel实例 可以在模型类中定义__str__方法,字典统一queryset...-- 用法:Asset.objects.filter(属性1=值1,属性2=值2),当多个属性在一起为与关系 作用:返回包含此条件的全部数据集 返回值:QuerySet容器对象,内部存放模块实例 # 查询数据库中...",i.create_date) # 查询数据库中 create_user为admin的并且系统为Linux的 from monitor.models import Asset info = Asset.objects.filter...:Asset.objects.exclude(条件) 作用:返回不包含此条件的数据集 # 查询数据库中 create_user为admin的并且系统为Linux以外的服务器信息 from monitor.models

    85520

    Django学习-第八讲:django ORM数据库查询,修改等操作

    1.查询操作 查找是数据库操作中一个非常重要的技术。查询一般就是使用filter、exclude以及get三个方法来实现。我们可以在调用这些方法的时候传递不同的参数来实现查询需求。...在ORM层面,这些查询条件都是使用field+__+condition的方式来使用的。 1.1.查询条件 1 .exact 使用精确的=进行查找。...SQL语句 select * from article where id=14; select * from article where id IS NULL; article.query,可以得到Django...article = Article.objects.filter(title__iexact='hello world') 那么以上的查询就等价于以下的SQL语句: select * from article...而exact翻译成sql语句左右两边是没有百分号的,意味着使用的是精确的查询。 4.icontains 大小写不敏感的匹配查询。

    52730

    Django之ORM F与Q查询

    Django 的 ORM 是创建 SQL 去查询和操作数据库的一个 Python 式的方式。 F查询 Q查询 F 查询 在前几个小章节里,构造的过滤器都只是将字段值与某个常量做比较。...Django 提供了 F() 来做这样的比较。F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。...示例: 查询浏览数大于评论数的文章 Django 支持 F() 对象之间以及 F() 对象和常数之间的加减乘除和取模的操作。...例如:在所有标题后面加上(原创) Q 查询 filter() 等方法中的关键字参数查询都是一起进行 "AND"。如果需要执行更复杂的查询(例如:OR 语句)可以使用 Q 对象。...同时,Q 对象可以使用 ~ 操作符取反,这允许组合正常的查询和取反(NOT)查询。 示例: 查询作者名字是“小团子”并且不是2018年发表的文章的标题。 查询函数可以混合使用 Q 对象和关键字参数。

    1.1K40

    Django ORM (一) 创建数据库

    创建一个 Django 项目及应用 django-admin startproject orm cd orm python manage.py startapp app01 在 models.py...上创建数据库结构 from django.db import models class Publisher(models.Model): name = models.CharField(max_length...'app01', ] 初始化数据库 # 使用命令行进入项目下 # 生成同步数据库的脚本: python manage.py makemigrations #同步数据库: python manage.py...#CharField 要求必须有一个参数 maxlength, 用于从数据库层和Django校验层限制该字段所允许的最大字符数. (2) IntegerField #用于保存一个整数....Field重要参数 (1) null : 数据库中字段是否可以为空 (2) blank: django的 Admin 中添加数据时是否可允许空值 (3) default:设定缺省值 (4) editable

    1.4K10

    Django使用Channels实现websocket

    由于项目有个需要实时显示状态的需求,搜索了各种实现方法,看来只有websocket最靠谱,但django原生是不支持websocket的,最终发现了chango-channels这个项目。...Channels 首先放上官方文档 安装配置 安装channels 如果使用的django是1.9包括以上的话,可以不用输入文档中-U参数,直接使用pip在终端中输入如下命令即可 $ pip install...在INSTALLED_APPS中添加channels INSTALLED_APPS = ( 'django.contrib.auth', 'django.contrib.contenttypes...', 'django.contrib.sessions', 'django.contrib.sites', ......使用类视图 django有一种类视图,在channels这里也可以,使用类视图可以让代码看着更简洁明了 类视图可以将三种状态,连接,收到消息,关闭的时候写到一个类中,原来的consumers.py代码就可以改为如下代码

    2.5K20

    Django进阶-9-ORM分组与聚合查询

    一 、ORM 查询性能 ① 普通查询 #for循环10次发送10次数据库查询请求 obj_list=models.Articles.objects.all() for row in obj_list...: print(row.name) 这种查询方式第一次发送 查询请求每for循环一次也会发送查询请求 ② select_related() 结果为对象 注意query_set类型的对象...查询时主动完成连表形成一张大表,for循环时不用额外发请求; 试用场景: 节省硬盘空间,数据量少时候适用相当于做了一次数据库查询; obj_list=models.Articles.objects.all...models.Articles.objects.all().prefetch_related('category') for obj in obj_list: print(obj.category.name) 二、ORM...from django.db.models import Avg,Sum,Max,Min #求书籍的平均价 ret=models.Book.objects.all().aggregate(Avg('price

    1K20
    领券