首页
学习
活动
专区
圈层
工具
发布

Django(19)QuerySet API

其实模型名字.objects是一个django.db.models.manager.Manager对象,而Manager这个类是一个“空壳”的类,他本身是没有任何的属性和方法的。...,返回一个新的QuerySet。...比如要获取标题中带有hello字符串的文章以及他的所有标签,示例代码如下: from django.db import connection articles = Article.objects.prefetch_related...filter的,只有两次sql查询 for sql in connection.queries: print(sql) 那如果确实是想要在查询的时候指定过滤条件该如何做呢,这时候我们可以使用django.db.models.Prefetch...Django将QuerySet转换为SQL语句去执行的五种情况 迭代:在遍历QuerySet对象的时候,会首先先执行这个SQL语句,然后再把这个结果返回进行迭代。

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

    django合并多个queryset

    这几天正在做一个关于权限控制的django框架,今天上午遇见了一个bug,因为我的需求是,每个人拥有的权限不同,所以你所能够访问的菜单也不同,那么这时候不同的人员访问不同的菜单是不一样的。...那么我可以把他所能够操作的菜单通过关联表的id查出来,但是我前台的代码是只能解析一个queryset的,那么我便利用chain方法将他们变为一个queryset; 以下是我的代码: all_actor...menu_list = chain(all_actor) print(menu_list) return menu_list django...queryset 合并 通过自带的方法: a1 = User.objects.filter(id__gt=8) a2 = User.objects.filter(id__lt=4) a3 = a1...| a2 注:这种方式合并的结构还是一个queryset,相当于a3把a1和a2的条件合并了,推荐,因为可以用order_by等函数了 只能合并同种model对象的数据` 2, 用python的chain

    3K30

    Django中的QuerySet

    一、QuerySet   查询集,类似一个列表,包含了满足查询条件的所有项。QuerySet 可以被构造,过滤,切片,做为参数传递,这些行为都不会对数据库进行操作。只有你查询的时候才真正的操作数据库。...意味着QuerySet是惰性执行的----即创建查询集不会带来任何的数据库访问,直到查询集需要求值的时候,Django才会真正运行这个查询。... exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象 values(*field): 返回一个ValueQuerySet——一个特殊的QuerySet... distinct(): 从返回结果中剔除重复纪录(如果你查询跨越多个表,可能在计算QuerySet时得到重复的结果。... count(): 返回数据库中匹配查询(QuerySet)的对象数量。

    1.7K32

    Django之QuerySet详解

    kind参数应为"year","month"或"day"。 结果列表中的每个datetime.date对象被截取为给定的类型。 "year" 返回对应该field的所有不同年份值的列表。...例如,要对2010年发布的所有博客条目启用评论,可以执行以下操作: >>> Entry.objects.filter(pub_date__year=2010).update(comments_on=False...例如同时更新comments_on和headline字段: >>> Entry.objects.filter(pub_date__year=2010).update(comments_on=False,...__year=2010).update(comments_on=False) 132 如果你只是更新一下对象,不需要为对象做别的事情,最有效的方法是调用update(),而不是将模型对象加载到内存中。...如果想更新一个具有自定义save()方法的模型的记录,请循环遍历它们并调用save(),如下所示: for e in Entry.objects.filter(pub_date__year=2010):

    3.1K20

    Django学习笔记:QuerySet API

    其实模型名字.objects是一个django.db.models.manager.Manager对象,而Manager这个类是一个“空壳”的类,他本身是没有任何的属性和方法的。...比如要获取标题中带有hello字符串的文章以及他的所有标签,示例代码如下: from django.db import connection articles = Article.objects.prefetch_related...filter的,只有两次sql查询 for sql in connection.queries: print(sql) 那如果确实是想要在查询的时候指定过滤条件该如何做呢,这时候我们可以使用django.db.models.Prefetch...什么时候Django会将QuerySet转换为SQL去执行: 生成一个QuerySet对象并不会马上转换为SQL语句去执行。...说明上面的QuerySet并没有真正的执行。 在以下情况下QuerySet会被转换为SQL语句执行: 迭代:在遍历QuerySet对象的时候,会首先先执行这个SQL语句,然后再把这个结果返回进行迭代。

    78020

    Django学习笔记之Django QuerySet的方法

    一般情况下,我们在写Django项目需要操作QuerySet时一些常用的方法已经满足我们日常大多数需求,比如get、filter、exclude、delete神马的感觉就已经无所不能了,但随着项目但业务逻辑越来越复杂...django才会从数据库读取这些数据,感觉在数据量变大后用这个方法很nice,具体用法如下: Blog.objects.defer("content").filter(publish=True).defer...答案在这里: django.models 的 on_delete参数,此参数有以下几个可选值: CASCADE:这就是delete()的默认选项,也就是关联删除 PROTECT:如果删除的model obj...settings.AUTH_USER_MODEL, on_delete=models.SET(get_sentinel_user)) 11、fields lookups 强大滴django...fields lookups,具体可选参数有: iexact icontains in istartwith gt gte lt lte endwith iendwith range year month

    72950
    领券