Django ORM 中过滤 JSON 数据

简介

首先,我们假设您有一个名为 MyModel 的 Django 模型,它包含一个 JSONField 类型的字段,名为 data。这个 data 字段可以存储各种 JSON 格式的数据。

过滤 JSON 字段中的键值对

您可以使用双下划线 __ 语法来访问 JSON 字段中的嵌套键值对。例如:

python 复制代码
# 过滤 data 字段中 "name" 键对应的值为 "John"
results = MyModel.objects.filter(data__name="John")

# 过滤 data 字段中 "address" 键下的 "city" 键对应的值为 "New York"
results = MyModel.objects.filter(data__address__city="New York")

过滤 JSON 数组

如果 JSON 字段中包含数组,您可以使用 contains lookup 来过滤数组中的元素:

python 复制代码
# 过滤 data 字段中 "tags" 键对应的数组包含 "python"
results = MyModel.objects.filter(data__tags__contains="python")

使用 has_key 过滤存在特定键的 JSON 字段

您可以使用 has_key lookup 来检查 JSON 字段中是否存在特定的键:

python 复制代码
# 过滤 data 字段中包含 "email" 键的记录
results = MyModel.objects.filter(data__has_key="email")

使用 JSONField 的 contains lookup 进行模糊搜索:

JSONField 提供了 contains lookup,您可以使用它来进行模糊搜索:

python 复制代码
# 模糊搜索 data 字段中 "name" 键对应的值包含 "Jo"
results = MyModel.objects.filter(data__name__contains="Jo")

使用 Q 对象进行复杂查询

您还可以使用 Django ORM 的 Q 对象来构建更复杂的查询:

python 复制代码
from django.db.models import Q

# 过滤 data 字段中 "name" 键对应的值为 "John",或 "tags" 键对应的数组包含 "python"
results = MyModel.objects.filter(Q(data__name="John") | Q(data__tags__contains="python"))

需要注意的是,不同的数据库可能会有不同的 JSON 查询语法,您需要查看所使用数据库的文档,确保正确使用。此外,如果您使用的是 PostgreSQL 数据库,您还可以利用其内置的 JSON 函数进行查询。

相关推荐
董世昌4137 分钟前
JavaScript闭包终极指南:从原理到实战(2025版)
json
BD_Marathon4 小时前
【JavaWeb】JS_JSON在客户端的使用
开发语言·javascript·json
松☆10 小时前
OpenHarmony + Flutter 混合开发实战:构建高性能离线优先的行业应用(含 SQLite 与数据同步策略)
数据库·flutter·sqlite
U盘失踪了12 小时前
Django Bootstrap 下载到本地使用,避免 CDN 超时
python·django·bootstrap
U盘失踪了12 小时前
Django 登录注册功能实现
后端·python·django
U盘失踪了12 小时前
Django 登录注册功能实现-样式优化
后端·python·django
csdn_aspnet13 小时前
C# .NETCore json字符串压缩为一行
c#·json·.netcore
1nv1s1ble13 小时前
[c++] cpp快速添加sqlite_orm
c++·sqlite
B站计算机毕业设计之家13 小时前
大数据项目:基于python电商平台用户行为数据分析可视化系统 电商订单数据分析 Django框架 Echarts可视化 大数据技术(建议收藏)
大数据·python·机器学习·数据分析·django·电商·用户分析
吳所畏惧1 天前
少走弯路:uniapp里将h5链接打包为apk,并设置顶/底部安全区域自动填充显示,阻止webview默认全屏化
android·安全·uni-app·json·html5·webview·js