import os

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "test.setting")
import django django.setup() # from django.core.management import call_command
#
#
# call_command("test", "")
from django.db import models
from chat.models import Dog from django.db.models.functions import Cast Dog.objects.create(name="Meg", age=1, data={"breed": "collie", "owner": {"name": "Tom", "age": 10}}, food=["noodles", "fuck"])
Dog.objects.create(name="WangWang", age=1, data={"breed": "collie", "owner": {"name": "LiMing", "age": 10}}, food=["bone", ])
Dog.objects.annotate(
title=Cast("data__breed", models.TextField()),
).filter(title__regex="c.*") Dog.objects.annotate(
title=Cast("food__*", models.TextField()),
).filter(title__contains="nood") from chat.models import Cat Dog.objects.annotate(
title=Cast("data__owner__name", models.TextField()),
).filter(title__regex="t.*") Dog.objects.annotate(
title=Cast("food", models.TextField()),
).filter(title__regex="t.*") Cat.objects.annotate(
title=Cast("food__0", models.TextField())
).values("title") # Cat.objects.annotate(
# food="food"
# ).filter(food="11") Dog.objects.filter(data__owner__age__gt=1)
from django.db.models import Q
from django.utils import timezone Dog.objects.filter(create_time__lt=timezone.now())
Dog.objects.filter(name__icontains="e")
Dog.objects.filter(name__startswith="M") # 区分大小
Dog.objects.filter(name__istartswith="M") # 不区分大小写
Dog.objects.filter(name__endswith="g") # 区分大小
Dog.objects.filter(name__iendswith="g") # 不区分大小写
Dog.objects.filter(name__regex=".*?g") # 区分大小写
Dog.objects.filter(name__iregex=".*?G") # 不区分大小写
Dog.objects.filter(age__exact=1)
Dog.objects.filter(age__in=[1, 2, 3])
Dog.objects.exclude(age=1)
Dog.objects.filter(~Q(age=1))
Dog.objects.filter(age__gt=1) # 大于
Dog.objects.filter(age__gte=1) # 大于等于
Dog.objects.filter(age__lt=2) # 小于
Dog.objects.filter(age__lte=2) # 小于等于 Dog.objects.filter(create_time__gt=timezone.now()) # 大于
Dog.objects.filter(create_time__gte=timezone.now()) # 大于等于
Dog.objects.filter(create_time__lt=timezone.now()) # 小于
Dog.objects.filter(create_time__lte=timezone.now()) # 小于等于
Dog.objects.filter(food__contains="noodles")
Dog.objects.filter(~Q(food__contains="noodles"))
Dog.objects.filter(age__in=[1, 2, 4])
Dog.objects.filter(age__range=(1, 10)) Dog.objects.annotate(
title=Cast("food", models.TextField()),
).filter(title__regex="t.*")
from chat.models import Cat Cat.objects.annotate(title=Cast("food", models.TextField())).filter(title__regex="1.*")
Cat.objects.filter(food__0__contains="1")
Cat.objects.annotate(
title=Cast("food", models.TextField()),
).filter(title__contains="11,") # 精确查找
Cat.objects.annotate(
title=Cast("food", models.TextField()),
).filter(title__regex="") value = "11"
# rf"[\{{|,]{value}[,|\}}]" Cat.objects.annotate(
title=Cast("food", models.TextField()),
).filter(title__regex=rf"[\{{|,]{value}[,|\}}]") q = Q()
for item in ["{{item},", ",{item}},", ",{item},", "{{item}}"]:
q |= Q(title__contains=item.replace("{item}","11")) Cat.objects.annotate(
title=Cast("food", models.TextField()),
).filter(q) from django.contrib.postgres.fields import ArrayField
Cat.objects.annotate(
title=Cast("food", ArrayField(models.TextField())),
)
# .filter(q) # FloatField Dog.objects.annotate(
food=Cast("data__owner__age", models.IntegerField()),
).filter(food=10) from django.db.models import F, Value, TextField
from django.db.models.expressions import Func from django.contrib.postgres.fields import ArrayField Cat.objects.annotate(
some_field_splitted=Func(
F('food'),
Value(","),
function='regexp_split_to_array',
output_field=ArrayField(TextField())
)
).filter() # Dog.objects.annotate(
# # some_field_splitted=Cast("food",Func(
# # # F('food'),
# # # Value(","),
# # function='regexp_split_to_array',
# # output_field=ArrayField(TextField())
# # )
# # )) from django.contrib.postgres.fields import JSONField, ArrayField
Dog.objects.annotate(
title=Cast("food__any", ArrayField(JSONField(models.TextField()))),
).filter(title__0="1")

django orm 筛选的更多相关文章

  1. Django orm 常用查询筛选总结

    本文主要列举一下django orm中的常用查询的筛选方法: 大于.大于等于 小于.小于等于 in like is null / is not null 不等于/不包含于 其他模糊查询 model: ...

  2. Django ORM那些相关操作

    一般操作 https://docs.djangoproject.com/en/1.11/ref/models/querysets/         官网文档 常用的操作 <1> all() ...

  3. django orm 及常用参数

    一些说明: 表myapp_person的名称是自动生成的,如果你要自定义表名,需要在model的Meta类中指定 db_table 参数,强烈建议使用小写表名,特别是使用MySQL作为后端数据库时. ...

  4. Django ORM中常用字段和参数

    一些说明: 表myapp_person的名称是自动生成的,如果你要自定义表名,需要在model的Meta类中指定 db_table 参数,强烈建议使用小写表名,特别是使用MySQL作为后端数据库时. ...

  5. Django ORM那些相关操作zi

    Django ORM那些相关操作   一般操作 看专业的官网文档,做专业的程序员! 必知必会13条 <1> all(): 查询所有结果 <2> filter(**kwargs) ...

  6. Django 2.0 学习(16):Django ORM 数据库操作(下)

    Django ORM数据库操作(下) 一.增加表记录 对于表单有两种方式: # 方式一:实例化对象就是一条表记录france_obj = models.Student(name="海地&qu ...

  7. Django学习笔记之Django ORM相关操作

    一般操作 详细请参考官方文档 必知必会13条 <> all(): 查询所有结果 <> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 <> ...

  8. Django ORM哪些操作

    一般操作 看专业的官网文档,做专业的程序员! 必知必会13条 <1> all(): 查询所有结果 <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 ...

  9. python 终级篇 django ---ORM操作

                                       一般操作                                                          必会的 ...

  10. Django ORM --- 建表、查询、删除基础

    1.什么是ORM ORM的全称是Object Relational Mapping,即对象关系映射.它的实现思想就是将关系数据库中表的数据映射成为对象,以对象的形式展现,这样开发人员就可以把对数据库的 ...

随机推荐

  1. AISing Programming Contest 2021(AtCoder Beginner Contest 202) 简单题解记录

    补题链接:Here A - Three Dice 水题,问给定三次摇色子的正面,请问3次结果以后相对面的点数和 cout << (21 - a - b - c) << &quo ...

  2. 对话开发者:Serverless 落地的困境与破局

    作者 | 阿里云开发者社区.InfoQ 从 2012 年提出 Serverless 到今年 2022 年刚好十年. 过去十年,上云是确定性趋势,在这个阶段企业一开始的关注点在于如何实现平滑上云.随着越 ...

  3. COM组件开发-关于在开发环境下COM组件的(来自 HRESULT 的异常:0x80080005 (CO_E_SERVER_EXEC_FAILURE)) 以及 在CLR语言下可能报错 未能加载文件或程序集“Interop.xxx 的问题

    1.关于在开发环境下COM组件的(来自 HRESULT 的异常:0x80080005 (CO_E_SERVER_EXEC_FAILURE)) 开发环境下,COM组件注册的文件 不一定是你自己现在程序调 ...

  4. freeswitch的ACL规则

    概述 freeswitch是一款好用的VOIP开源软交换平台. VOIP公共网络中的安全问题是最重要的问题,我们必须对网络端口的访问权限做出限制. ACL全称Access Control List,意 ...

  5. sublime_text4 2023最新版 激活教程

    官网 Sublime HQ - Remarkable Software 东西在教学的时候还是挺好用的,就是要付费购买,穷,没钱 买不起,自己动手丰衣足食. 下载安装包 我现在最新版是4.4152 下面 ...

  6. 理解 docker volume

    1. docker volume 简介 文章 介绍了 docker image,它由一系列只读层构成,通过 docker image 可以提高镜像构建,存储和分发的效率,节省时间和存储空间.然而 do ...

  7. spring boot 中WebMvcConfigurer相关使用总结

    本文为博主原创,未经允许不得转载: WebMvcConfigurer 为spring boot中的一个接口,用来配置web相关的属性或工具插件,比如消息转换器,拦截器,视图处理器,跨域设置等等. 在S ...

  8. Laravel - 使用ajax

    一,前台模板文件  index.blade.php <!DOCTYPE html> <meta name="_token" content="{{ cs ...

  9. 百度网盘(百度云)SVIP超级会员共享账号每日更新(2023.12.11)

    一.百度网盘SVIP超级会员共享账号 可能很多人不懂这个共享账号是什么意思,小编在这里给大家做一下解答. 我们多知道百度网盘很大的用处就是类似U盘,不同的人把文件上传到百度网盘,别人可以直接下载,避免 ...

  10. 【转帖】Alpaca 7B:斯坦福从LLaMA-7B微调的语言模型

    https://www.jianshu.com/p/f8f8f660d2c3 https://crfm.stanford.edu/2023/03/13/alpaca.html https://crfm ...