django orm 筛选
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 筛选的更多相关文章
- Django orm 常用查询筛选总结
本文主要列举一下django orm中的常用查询的筛选方法: 大于.大于等于 小于.小于等于 in like is null / is not null 不等于/不包含于 其他模糊查询 model: ...
- Django ORM那些相关操作
一般操作 https://docs.djangoproject.com/en/1.11/ref/models/querysets/ 官网文档 常用的操作 <1> all() ...
- django orm 及常用参数
一些说明: 表myapp_person的名称是自动生成的,如果你要自定义表名,需要在model的Meta类中指定 db_table 参数,强烈建议使用小写表名,特别是使用MySQL作为后端数据库时. ...
- Django ORM中常用字段和参数
一些说明: 表myapp_person的名称是自动生成的,如果你要自定义表名,需要在model的Meta类中指定 db_table 参数,强烈建议使用小写表名,特别是使用MySQL作为后端数据库时. ...
- Django ORM那些相关操作zi
Django ORM那些相关操作 一般操作 看专业的官网文档,做专业的程序员! 必知必会13条 <1> all(): 查询所有结果 <2> filter(**kwargs) ...
- Django 2.0 学习(16):Django ORM 数据库操作(下)
Django ORM数据库操作(下) 一.增加表记录 对于表单有两种方式: # 方式一:实例化对象就是一条表记录france_obj = models.Student(name="海地&qu ...
- Django学习笔记之Django ORM相关操作
一般操作 详细请参考官方文档 必知必会13条 <> all(): 查询所有结果 <> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 <> ...
- Django ORM哪些操作
一般操作 看专业的官网文档,做专业的程序员! 必知必会13条 <1> all(): 查询所有结果 <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 ...
- python 终级篇 django ---ORM操作
一般操作 必会的 ...
- Django ORM --- 建表、查询、删除基础
1.什么是ORM ORM的全称是Object Relational Mapping,即对象关系映射.它的实现思想就是将关系数据库中表的数据映射成为对象,以对象的形式展现,这样开发人员就可以把对数据库的 ...
随机推荐
- AISing Programming Contest 2021(AtCoder Beginner Contest 202) 简单题解记录
补题链接:Here A - Three Dice 水题,问给定三次摇色子的正面,请问3次结果以后相对面的点数和 cout << (21 - a - b - c) << &quo ...
- 对话开发者:Serverless 落地的困境与破局
作者 | 阿里云开发者社区.InfoQ 从 2012 年提出 Serverless 到今年 2022 年刚好十年. 过去十年,上云是确定性趋势,在这个阶段企业一开始的关注点在于如何实现平滑上云.随着越 ...
- COM组件开发-关于在开发环境下COM组件的(来自 HRESULT 的异常:0x80080005 (CO_E_SERVER_EXEC_FAILURE)) 以及 在CLR语言下可能报错 未能加载文件或程序集“Interop.xxx 的问题
1.关于在开发环境下COM组件的(来自 HRESULT 的异常:0x80080005 (CO_E_SERVER_EXEC_FAILURE)) 开发环境下,COM组件注册的文件 不一定是你自己现在程序调 ...
- freeswitch的ACL规则
概述 freeswitch是一款好用的VOIP开源软交换平台. VOIP公共网络中的安全问题是最重要的问题,我们必须对网络端口的访问权限做出限制. ACL全称Access Control List,意 ...
- sublime_text4 2023最新版 激活教程
官网 Sublime HQ - Remarkable Software 东西在教学的时候还是挺好用的,就是要付费购买,穷,没钱 买不起,自己动手丰衣足食. 下载安装包 我现在最新版是4.4152 下面 ...
- 理解 docker volume
1. docker volume 简介 文章 介绍了 docker image,它由一系列只读层构成,通过 docker image 可以提高镜像构建,存储和分发的效率,节省时间和存储空间.然而 do ...
- spring boot 中WebMvcConfigurer相关使用总结
本文为博主原创,未经允许不得转载: WebMvcConfigurer 为spring boot中的一个接口,用来配置web相关的属性或工具插件,比如消息转换器,拦截器,视图处理器,跨域设置等等. 在S ...
- Laravel - 使用ajax
一,前台模板文件 index.blade.php <!DOCTYPE html> <meta name="_token" content="{{ cs ...
- 百度网盘(百度云)SVIP超级会员共享账号每日更新(2023.12.11)
一.百度网盘SVIP超级会员共享账号 可能很多人不懂这个共享账号是什么意思,小编在这里给大家做一下解答. 我们多知道百度网盘很大的用处就是类似U盘,不同的人把文件上传到百度网盘,别人可以直接下载,避免 ...
- 【转帖】Alpaca 7B:斯坦福从LLaMA-7B微调的语言模型
https://www.jianshu.com/p/f8f8f660d2c3 https://crfm.stanford.edu/2023/03/13/alpaca.html https://crfm ...